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国家 制定 的 “互联 网 十 ”行动 计划 将 推动 移动 互联 网 、 云 计算 、 大 数据 、 物 联网 等 与 现代 
制造 业 结合 ,促进 电子 商务 .工业 互联 网 和 互联 网 金融 健康 发 展 , 引 导 互 联网 企业 拓展 国际 
市 场 。 为 实施 “互联 网 十 ”这 一 战略 目标 ,教育 应 该 先行 。 如 何 培养 和 储备 “互联 网 十 ”技术 开 
发 和 应 用 的 综合 型 人 才 , 引 导 “ 互 联网 十 ”技术 未 来 的 生力军 一 一 大 学 生 充分 利用 “互联 网 十 ” 
技术 解决 专业 领域 的 实际 应 用 问题 ,已 成 为 教育 工作 者 的 重要 任务 ,也 是 吸 待 解决 的 问题 , 需 
要 教育 工作 者 进一步 学 习 和 探讨 。 

在 基于 互联 网 环境 下 的 大 数据 \ 信 息 化 社会 的 今天 ,本 书 的 宗旨 是 探讨 和 解决 以 下 问 
题 : 如 何 将 大 学 生 培 养 成 为 “互联 网 十 ”的 建设 者 和 实践 者 ,而 不 是 被 动 享用 “互联 网 十 ” 
资源 的 普通 用 户 ; 如 何 将 计算 机 网 络 技术 与 其 他 学 科 的 理论 .技术 和 艺术 相 融 合 , 增 强 学 
生 在 社会 实践 中 借鉴 .引入 计算 机 科学 、 网 络 的 理念 和 技术 方法 来 分 析 问 题 .解决 问题 的 
能 力 ; 如 何 将 现实 问题 转化 成 计算 机 网 络 技术 能 解决 的 各 种 形式 ,达到 用 计算 机 网 络 技术 
处 理 各 种 复杂 事务 之 目的 ;如 何 提 升学 生 的 计算 思维 、 人 逻辑 思维 、 分 析 问 题 以 及 用 计算 机 
网 络 技 术 解 决 现实 问题 的 能 力 ,掌握 用 计算 机 网 络 技 术 解 决 实际 问题 的 过 程 、 实 现 原 理 和 
技术 方法 ,突破 现 有 技术 手段 (软件 ) ,提高 计算 机 网 络 的 应 用 水 平 , 增 大 计算 机 网 络 技 术 
的 应 用 领域 和 深度 ,增强 各 学 科 的 创新 能 力 。 

经 过 近 些 年 的 社会 调研 .学 习 、 探 索 、 研 究 以 及 教学 实践 ,综合 精品 资源 共享 课 和 大 规 
模 网 络 开 放 课 程 (Massive Open Online Courses,MOOC 或 慕 课 ) 的 教学 方式 改革 与 建 
设 , 以 及 基于 计算 思维 的 计算 机 基础 课程 改革 ,我 校 组 织 了 长 期 从 事 计算 机 基础 教学 、 负 
责 精品 课程 及 优秀 教学 团队 建设 且 有 互联 网 技术 应 用 、 开 发 及 教学 经 验 的 专业 教师 进行 
了 专题 讨论 和 研究 ,针对 目前 发 行 的 一 些 相 关 技 术 参 考 书 进 行 了 认真 剖析 .归纳 .总 结 和 
提炼 , 取 其 精华 ,去 其 糟粕 ,为 编写 这 方面 的 教科 书 夯实 了 基础 。 

本 次 再 版 ,在 教学 内 容 的 完整 性 .系统 性 .连贯 性 .逻辑 性 、 可 读 性 以 及 实用 性 等 方面 
下 了 很 大 功夫 ,与 前 期 版 本 相 比 ,更 适合 教学 和 IT 技术 人 员 参 考 。 

在 编写 本 教材 的 过 程 中 ,作者 遵循 教学 工作 的 基本 规律 ,采用 “案例 教学 法 ”将 教学 和 
实用 技术 相 结合 ,理论 联系 实际 ,由 浅 入 深 , 循 序 渐进 ,以 人 才 招聘 为 案例 讲解 相关 内 容 ， 
使 读者 在 学 习 过 程 中 有 的 放 矢 ,通过 个 案 掌 握 解决 一 般 问题 的 过 程 和 技术 方法 。 按 照 计 
算 思 维 课程 改革 的 精神 实质 ,本 书 以 面向 案例 .任务 和 问题 求解 的 教学 思想 为 主线 , 较 科 
学 地 体现 了 教学 内 容 、 知 识 点 和 技能 点 ,以 使 读者 能 够 掌握 开发 一 个 完整 互联 网 实用 软 





件 的 整体 过 程 、 总 体 思路 和 设计 方法 ,引导 读者 开发 和 设计 解决 专业 领域 实际 问题 的 互联 
网 应 用 软件 。 

数据 库 技术 是 互联 网 技术 的 基石 ,互联 网 技术 只 有 与 数据 库 技 术 有 机 地 结合 起 来 , 才 
能 体现 出 其 巨大 的 作用 。 因 此 ,本 套 教材 涵盖 数据 库 技术 应 用 、 网 页 设计 和 网 络 应 用 程序 
设计 三 大 主题 。 本 套 教材 包括 主教 材 和 实践 指导 两 本 书 。 主 教材 由 宋 长 龙 和 曹 成 志 组 织 
编写 并 负责 修改 和 统 稿 , 共 14 章 和 两 个 附录 ,具体 内 容 及 参 编 的 教师 分 工 如 下 : 


















































作 者 内 容 E-mail 地 址 
刘向东 第 1 章 网 站 环境 设计 基础 Lxdong@jlu. edu. cn 
第 2 章 数据 库 逻 辑 设 计 及 数据 库 系统 结构 
宋 长 龙 第 3 章 ”MySQL 数据 库 管理 与 维护 Scl@jlu. edu. cn 
第 4 章 数据库 访问 及 结构 化 查询 语言 
曹 成 志 第 5 章 ”MySQL 程序 设计 Caocz@jlu. edu. cn 
李 锐 第 6 章 Dreamweaver 及 静态 网 页 设计 基础 Lir@jlu. edu. cn 
刘向东 第 7 章 静态 网 页 设计 Lxdong@jlu. edu. cn 
曹 成 志 第 8 章 PHP 程序 设计 基础 Caocz@jlu. edu. cn 
周 棚 第 9 章 PHP 程序 设计 Zhouxu@jlu. edu. cn 
昌 楠 第 10 章 动态 网 页 及 程序 设计 Lvn@jlu. edu. cn 
第 11 章 会 话 管理 及 应 用 a 
分 密 a - Zoumi@jlu. edu. cn 
第 12 章 移动 互联 网 网 页 及 程序 设计 
重 安宁 第 13 章 “BBS 系统 的 程序 设计 Mengan@jlu. edu. cn 
刘向东 第 14 章 人 才 招 聘 网 站 综合 设计 Lxdong@jlu. edu. cn 
曹 成 志 下 人 Caocz@jlu. edu. cn 
附录 B PHP 常用 运算 符 及 函数 








主教 材 每 章 配 有 符合 标准 化 考试 要 求 的 大 量 习 题 ( 填 空 题 . 单 选 题 和 多 选 题 ) .程序 设 
计 题 和 思考 题 ;实践 指导 辅 教材 包括 验证 性 .设计 性 和 创新 性 实验 题目 .实验 过 程 指导 以 
及 主教 材 的 习题 分 析 及 解答 , 供 读者 自主 学 习 、 自 测 和 上 机 实践 参考 。 本 套 教 材 不 仅 可 以 
作为 高 等 院 校 .高 等 职业 技术 学 院 的 教材 ,也 可 以 作为 参加 全 国 计 算 机 等 级 考试 以 及 计算 
机 网 络 应 用 软件 研发 人 员 的 技术 参考 书 。 

作为 吉林 大 学 “十 三 五 ”规划 教材 ,本 套 教材 是 全 体 作 者 长 期 从 事 计算 机 基础 教学 和 
软件 开发 实践 经 验 的 总 结 和 共同 努力 的 成 果 。 在 此 对 给 予 作者 大 力 支持 和 为 本 书 付出 辛 
勤劳 动 的 教师 以 及 一 直 关 注 本 书 问世 的 读者 及 学 生 表示 囊 心 的 感谢 。 

由 于 时 间 仓促 和 作者 认 知 水 平 有 限 , 书 中 难免 有 遗漏 之 处 ,如 果 由 此 给 读者 带 来 不 
便 ,作者 深 表 歉意 ,也 屋 请 广大 读者 指出 不 妥 之 处 并 提出 修改 建议 ,以 便 帮助 我 们 弥补 不 
足 , 把 今后 的 教材 建设 得 更 好 ,为 读者 提供 更 易于 学 习 和 掌握 的 IT 技术 资料 。 
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网 站 环境 设计 基础 


在 网 络 技术 广泛 应 用 之 前 ,计算 机 软件 几乎 都 是 采用 集中 式 结构 的 单机 应 用 程序 , 程 
序 本 身 和 用 户 数据 安装 在 同一 台 计 算 机 中 ,基于 计算 机 操作 系统 实现 应 用 程序 对 数据 的 
管理 ,一 旦 操作 系统 或 计算 机 硬件 出 现 问题 ,用 户 数据 就 可 能 受 损 且 无 法 恢复 。 

随 着 计算 机 网 络 技术 的 发 展 和 互联 网 资源 的 跳跃 式 增长 ,用 户 对 数据 安全 逐渐 重视 ， 
对 网 络 资源 的 需求 日 益 提 高 。 计 算 机 软件 开始 将 程序 和 数据 合理 地 存放 在 本 地 计算 机 和 
专用 的 计算 机 服务 器 中 ,通过 网 络 完成 数据 操作 和 管理 。 由 于 这 种 网 络 应 用 程序 数据 安 
全 ,资源 共享 .访问 更 便捷 ,因此 逐渐 成 为 主流 的 程序 设计 方式 。 

在 当前 的 “互联 网 +” 和 大 数据 时 代 , 网 络 应 用 程序 展现 的 形式 不 断 丰富 ,功能 日 趋 
完善 ,特别 是 互联 网 应 用 的 普及 使 得 快速 而 有 效 地 开发 网 络 应 用 程序 将 成 为 社会 所 需要 
的 基本 技能 。 在 规划 设计 网 站 和 开发 网 络 应 用 程序 之 前 ,应 该 着 重 弄 清 下 列 问题 

(1) 需要 掌握 哪些 概念 和 技术 术语 ? 

(2) 互联 网 的 工作 原理 是 什么 ? 网 站 是 如 何 工作 的 ? 

(3) 要 创建 网 站 ,所 需要 的 技术 和 流程 是 什么 ? 

(4) 需要 哪些 软件 平台 ? 如 何 安装 .配置 和 测试 相关 的 软件 平台 ? 


1.1 网 络 应 用 程序 概述 


应 用 程序 是 指 为 某 些 特 定 任务 开发 的 计算 机 软件 ,由 用 户 界 面 和 运行 在 数据 上 的 任 
务 逻 辑 两 部 分 组 成 。 在 网 络 应 用 程序 中 ,用 户 界面 .数据 和 任务 旭 辑 可 以 安装 在 不 同 的 计 
算 机 中 ,可 以 使 用 本 地 计算 机 运行 程序 和 查看 结果 ,通过 网 络 获 取 服 务 和 资源 。 常 见 的 即 
时 通信 (聊天 ) 、 网 络 电话 、 网 页 浏览 网 络 上 传 下 载 和 远程 控制 等 程序 都 属于 网 络 应 用 
程序 。 

运行 一 个 网 络 应 用 程序 ,通常 需要 数据 库 支 持 和 多 台 可 连 网 计算 机 ,一 般 将 存储 数据 
的 计算 机 称 为 数据 库 服 务 器 ( 简称 服务 器 ) 或 数据 层 。 主 要 承担 数据 库 管理 ,如 创建 与 维 
护 数据 库 ,用户 权 限 验证 数据 一 致 性 检验 、 存 取 用 户 数据 ,数据 备份 和 数据 库 日 志 等 
任务 。 

将 网 络 中 可 以 访问 服务 器 的 其 他 计算 机 称 为 客户 端 或 表示 层 。 主 要 为 用 户 提 供 软 


件 的 工作 界面 ,包括 访问 数据 库 的 交互 工具 (如 字符 命令 .菜单 和 按钮 等 ) .输入 输出 数据 
窗口 界面 ( 由 文本 框 \ 选 项 列表 框 和 表格 等 控件 组 成 ) ,向 服务 器 发 送 用 户 请 求 (命令 )， 
接收 服务 器 返回 的 处 理 结果 。 

在 一 些 特殊 情况 下 (如 个 人 软件 开发 .数据 临时 检查 与 维护 .家庭 或 小 公司 的 数据 库 
等 ) ,一 台 计算 机 可 以 兼作 服务 器 和 客户 端 。 


1.1.1 网 络 应 用 程序 的 结构 


网 络 应 用 程序 一 般 由 表示 层 业务 逻辑 层 和 数据 访问 层 三 层 构 成 , 即 在 客户 端 与 数据 





























库 之 间 增 加 了 中 间 层 一 一 业务 逻辑 层 , 如 图 1-1 所 示 。 
表示 层 “ |- | 业务 逻辑 层 | 一 ~| 数据 访问 层 0 
图 1-1 网 络 应 用 程序 的 三 层 结构 示意 图 
1. 表示 层 


表示 层 是 最 接近 用 户 的 一 层 ,主要 负责 提供 与 用 户 直接 交互 .输入 输出 数据 的 界面 
(窗口 ) ,调用 业务 逻辑 层 传输 用 户 的 请 求 ( 命令 ) ,接收 业务 逻辑 层 返回 的 数据 并 以 一 定 
的 样式 和 格式 输出 。 


2. 业务 逻辑 层 


业务 逻辑 层 也 称 领域 层 ,功能 层 或 处 理 层 ,是 网 络 应 用 程序 的 核心 ,位 于 数据 访问 层 
与 表示 层 之 间 ,起 着 实现 应 用 程序 功能 和 数据 交换 的 承上启下 作用 ,接收 表示 层 的 请 求 ， 
按 业务 规则 完成 业务 流程 和 实现 业务 需求 。 

当 业 务 迎 辑 层 接收 到 表示 层 的 数据 相关 请 求 时 ,需要 进行 有 效 性 验证 (如 数据 项 值 、 
数据 格式 和 用 户 权限 等 检查 ) 或 相关 业务 处 理 ( 如 计算 、 分 类 和 统计 汇总 等 ) ,调用 数据 访 
问 层 , 接 收 数据 访问 层 返 回 的 数据 或 处 理 结果 后 ,再 进行 后 续 的 业务 处 理 。 


3. 数据 访问 层 


数据 访问 层 的 主要 功能 是 直接 访问 数据 文件 (如 数据 库 . 二 进 制 文件 .文本 文件 和 
XML 文件 等 ) ,根据 业务 迎 辑 层 的 调用 请 求 ,存储 和 读 取 数据 ,将 读 取 的 数据 返回 给 业务 
好 辑 层 , 为 业务 逻辑 层 提供 数据 服务 。 

总 之 ,对 于 数据 访问 层 而 言 , 业 务 逻 辑 层 是 调用 者 ;对 于 表示 层 而 言 , 业 务 逻 辑 层 是 被 
调用 者 ,三 层 之 间 既 独立 又 有 联系 ,使 得 网 络 应 用 程序 设计 和 运行 结构 更 加 清晰 。 但 这 并 
不 要 求 每 层 程序 必须 占用 一 台 计算 机 ,而 实际 应 用 中 可 能 将 两 或 三 层 程序 布置 在 同一 台 
计算 机 上 。 
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1.1.2 网 络 应 用 程序 的 模式 


网 络 应 用 程序 提供 了 单机 应 用 程序 不 能 实现 的 远程 服务 ,其 数据 集中 存放 ,统一 管 
理 , 不 受 地 域 和 时 间 限 制 , 很 好 地 保证 了 数据 的 安全 性 一 致 性 和 实时 性 。 但 是 网 络 应 用 
程序 受 限 于 服务 器 性 能 和 网 络 状况 ,可 能 带 来 响应 延迟 等 糟糕 的 用 户 体验 。 

为 使 网 络 应 用 程序 能 更 好 地 满足 系统 环境 和 实际 应 用 的 需求 ,网 络 应 用 程序 根据 表 
示 层 ,业务 逻辑 层 和 数据 访问 层 分 布 的 位 置 不 同 ,可 分 为 客户 端 /服务 器 ( Client/Server， 
C/S) 和 浏览 器 /服务 器 ( Browser/Server,B/S) 两 种 应 用 模式 。 


1. C/S 模式 


C/S 模式 是 一 种 典型 的 双 层 结构 ,分 为 客户 端 和 服务 器 端 两 部 分 。 每 个 客户 端 都 需 
要 安装 独立 的 应 用 程序 ,提供 前 台 界 面 ,接受 用 户 请 求 , 完 成 具体 业务 。 服 务 器 端 通常 只 
提供 后 台数 据 管理 和 并 发 控制 ,允许 通过 网 络 与 多 个 客户 端 相 连 。 

在 这 种 模式 中 ,客户 端 要 完成 表示 层 和 业务 逻辑 层 两 项 功能 ,负担 较 重 , 因 此 被 戏称 
“ 胖 " 客 户 端 。 此 外 ,客户 端 程序 和 服务 器 数据 交互 频繁 ,网 络 通信 数 据 量 大 ,需要 专用 网 
络 支持 ,比较 适合 在 单机 或 局 域 网 环境 。 

目前 ,适合 C/S 模式 的 应 用 程序 开发 工具 (语言 ) 有 很 多 ,例如 ,Visual Basic Visual C 
++\PowerBuilder 和 . NET 框架 等 ,都 是 常见 的 选择 。 


2. B/S 模式 


随 着 计算 机 网 络 应 用 领域 的 不 断 扩 大 ,在 某 些 应 用 中 C/S 模式 的 弱点 逐渐 显现 出 
来 。 例 如 ,发 布 .安装 .维护 .升级 和 用 户 培 训 等 较为 困难 ,维护 成 本 逐渐 提高 ,网 上 数据 量 
爆炸 性 增长 ,传输 速度 越 来 越 慢 等 。 

改进 这 些 问 题 的 总 体 思 路 是 对 客户 端 减 “ 肥 ”, 对 服务 器 端 增 * 胖 " 。 将 C/S 模式 中 客 
户 端的 业务 逻辑 层 移植 到 服务 器 端 ,客户 端 只 保留 表示 层 的 功能 ,通过 网 络 浏览 器 实现 ， 
这 就 是 网 络 应 用 程序 中 的 B/S 模式 。 

网 络 浏览 器 是 运行 在 客户 端的 轻 量 级 应 用 程序 ,实现 网 络 中 文件 的 传输 和 文件 内 容 
的 显示 。 由 于 浏览 器 与 业务 逻辑 层 无 关 ,无 需 复杂 的 逻辑 功能 和 数据 库 接 口 程序 ,不 用 配 
备 专用 的 网 络 硬件 ,使 得 B/S 模式 适合 各 种 网 络 环境 。 如 图 1-2 所 示 。 

在 B/S 模式 中 ,数据库 应 用 程序 的 表示 层 与 Web 浏览 器 的 设计 风格 .运行 环境 ( 方 
式 ) 和 操作 方法 等 统一 起 来 ,使 应 用 程序 更 容易 发 布 安装、 维护 .升级 和 用 户 培 训 。 另 
外 ,由 于 网 络 中 传输 的 数据 是 业务 逻辑 层 处理 后 的 结果 ,而 不 是 原始 数据 ,因此 ,降低 了 网 
络 中 的 数据 流量 ,提高 了 工作 效率 。 

目前 ,适合 B/S 模式 的 应 用 程序 开发 语言 有 PHP( Hypertext Preprocessor) 、JSP( Java 
Server Pages) .ASP ( Active Server Pages) 和 Perl 等 ,这 些 语言 各 有 特点 ,只 要 掌握 其 中 一 
种 语言 , 即 可 开发 网 络 应 用 程序 。 

总 之 ,C/S 和 B/S 两 种 模式 各 有 千秋 ,一 个 现实 的 网 络 应 用 系统 可 能 是 二 者 的 混合 
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中 浏览 器 客户 端 : 
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浏览 器 客户 端 : 
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图 1-2 网络 应 用 程序 的 B/S 模式 


体 。 例 如 ,在 数据 库 服务 器 所 在 的 局 域 网 中 ,采用 C/S 模式 可 以 减少 应 用 程序 的 层次 , 较 
容易 实现 ;各 类 业务 处 理 任务 分 散 到 客户 端 ,减轻 服务 器 负担 。 对 于 互联 网 用 户 ,采用 B/ 
S 模式 ,解决 应 用 程序 维护 和 数据 流量 等 问题 。 


1.1.3 ”网 页 ,网 站 和 网 络 应 用 程序 


谈 及 网 络 应 用 ,首先 想到 的 就 是 使 用 浏览 器 访问 网 站 ( Web Site) ,浏览 网 站 中 的 各 个 
网 页 ( Web page) 。 网 页 是 包含 文字 图片. 声音 .动画 和 视频 等 多 种 媒体 信息 的 页 面 文 
件 , 可 通过 浏览 器 下 载 并 显示 。 网 页 根据 运行 方式 和 信息 的 来 源 不 同 ,可 分 为 静态 网 页 和 
动态 网 页 。 


1. 静态 网 页 


静态 网 页 是 指使 用 标准 HTML( Hyper Text Markup Language, 超 文本 标记 语言 ) 设 计 
的 文本 文件 ,扩展 名 为 HTM 或 HTML。 静 态 网 页 通过 HTML 标签 描述 页 面 元 素 的 位 置 和 
特征 ,通过 浏览 器 将 各 个 元 素 解析 成 网 页 。 要 改变 页 面 内 容 , 只 能 在 服务 器 端 修改 静态 网 
页 文件 的 内 容 。 

早期 的 网 站 主要 由 静态 网 页 组 成 ,网 页 内 容 对 所 有 用 户 都 完全 相同 , 仅 用 作 信 息 发 布 
和 媒体 内 容 展示 。 有 些 网 页 包含 如 GIF 格式 的 动画 、FLASH 滚动 字幕 等 多 种 动态 的 效 
果 , 但 这 些 动态 效果 都 是 预先 设 定好 的 ,发 送 到 客户 端 浏 览 器 后 就 不 再 改变 ,仍然 属于 静 
态 网 页 。 


2. 动态 网 页 


动态 网 页 是 指 网 页 内 容 可 以 随时 间 环境 或 客户 不 同 而 自动 变化 的 网 页 。 例 如 ,常见 
的 论坛 .博客 .留言 板 和 搜索 引擎 等 实时 变化 的 网 页 ,都 属于 动态 网 页 。 

动态 网 页 通常 以 静态 网 页 为 基础 ,在 文件 中 添加 可 在 服务 器 端 直接 运行 的 脚本 程序 
(也 称 网 络 程序 ) 。 当 用 户 通过 浏览 器 访问 动态 网 页 时 ,服务 器 端 执行 脚本 程序 ,将 执行 
结果 转变 成 新 的 HTML 代码 ,发送 到 客户 端 浏览 器 进行 显示 。 使 用 动态 网 页 可 以 为 用 户 





基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


带 来 更 好 的 个 性 化 体验 ,并 通过 连接 数据 库 服务 器 增强 网 页 的 功能 和 服务 ,已 经 成 为 现代 
网 站 中 网 页 的 主要 形式 。 


3. 网 站 


网 站 是 一 种 通过 网 页 发 布 信息 或 提供 服务 的 网 络 媒体 ,访问 网 站 后 看 到 的 第 一 个 网 
页 称 为 主页 。 网 站 通过 链接 将 主页 与 网 站 其 他 网 页 组 织 到 一 起 ,为 用 户 提供 信息 及 工作 
界面 。 在 服务 器 端 ,通过 运行 服务 程序 和 数据 库 管 理 系统 维系 网 站 的 正常 工作 ,以 使 互联 
网 用 户 能 够 正常 地 访问 网 页 。 所 以 网 站 是 网 络 应 用 程序 架构 在 B/S 模式 上 的 典型 应 用 。 

网 站 的 组 成 相对 网 页 要 复杂 得 多 ,需要 提供 在 互联 网 上 的 访问 域名 .存放 空间 和 服务 
程序 。 

(1) 域名 (Domain Name) : 由 一 串 用 圆 点 分 隔 的 名 字 组 成 ,用 于 访问 互联 网 上 某 一 台 
计算 机 或 计算 机 组 ,是 便于 记忆 和 沟通 的 一 组 服务 器 地 址 。 例 如 百度 网 站 的 域名 是 
www. baidu. com ,用 户 可 以 通过 这 个 域名 登录 百度 的 网 站 服务 器 。 

(2) 空间 : 可 以 看 作 网 站 服务 器 端的 一 块 磁盘 空间 (文件 夹 ) ,用 来 存放 网 站 的 信息 ， 
例如 网 页 .音频 ,动画 和 视频 等 。 网 站 的 空间 可 以 是 网 络 建设 人 员 自 己 架 设 的 主机 空间 ， 
也 可 以 是 云端 服务 商 提供 的 虚拟 主机 。 

(3) 服务 器 程序 : 用 来 解析 并 辅助 动态 网 页 运行 的 软件 ,通常 包括 网 页 服务 器 程序 
和 数据 库 管 理 系统 。 需 要 注意 的 是 不 同 的 网 页 服务 器 程序 ,用 来 设计 动态 网 页 的 脚本 语 
言 也 不 同 。 





1.2 “互联 网 +” 概 述 


从 产业 发 展 周期 来 看 ,现在 的 网 络 发 展 还 处 于 大 幕 刚刚 拉 开 的 早期 阶段 ,移动 互联 网 
正在 以 一 种 令 人 热血 沸腾 且 充 满 不 确定 性 的 姿态 迅速 向 前 发 展 。 在 我 国 ,网 民 人 数 已 经 
突破 7 亿 , 无 数 的 资金 和 人 才 涌 进来 ,互联 网 的 发 展 为 国家 经 济 的 发 展 注入 了 强劲 的 
动力 。 

以 教育 ,金融 医疗 汽车 和 房地产 等 为 代表 的 主流 经 济 产业 都 正在 与 互联 网 结合 ,i 
图 依靠 互联 网 迅速 获得 流量 .客户 ,没有 互联 网 平台 的 传统 产业 公司 面临 被 淘汰 的 风险 。 
为 了 促进 传统 行业 的 互联 网 化 ,将 移动 互联 网 . 云 计算 ,大 数据 、 物 联网 等 信息 通信 技术 与 
各 行业 相 结合 ,推动 产业 转型 升级 ,提出 了 “互联 网 +” 概 念 。 


1.2.1 什么 是 “互联 网 +” 


“互联 网 +” 就 是 指 以 互联 网 平台 为 基础 ,充分 发 挥 互联 网 在 生产 要 素 和 产品 销售 中 
的 优化 和 集成 作用 ,将 互联 网 创新 成 果 深 度 融 入 经 济 社会 各 领域 中 ,提升 实体 经 济 的 创新 
力 和 生产 力 , 形 成 更 广泛 的 以 互联 网 为 基础 设施 和 实施 工具 的 一 种 经 济 发 展 新 形态 。 

通俗 来 说 ,“ 互 联网 +” 就 是 “互联 网 + 所 有 传统 行业 ” ,但 不 是 两 者 简单 的 相 加 ,而 是 
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(@) 


利用 信息 通信 技术 和 互联 网 平台 使 两 者 进行 深度 融合 。 我 国 提出 * 互 联网 + "行动 计划 ， 
将 推动 移动 互联 网 、 云 计算 、 大 数据 、 物 联网 等 与 现代 制造 业 结合 ,促进 电子 商务 、 工 业 互 
联网 和 互联 网 金融 健康 发 展 ,引导 互联 网 企业 拓展 国际 市 场 。 相 对 于 完全 垂直 型 的 传统 
行业 ,“ 互 联网 +" 具 有 以 下 特点 。 

(1) 跨 界 融 合 。“ 互 联网 +" 不 仅仅 是 将 某 个 单一 行业 和 互联 网 业 进行 融合 ,而 可 能 
影响 整个 传统 行业 的 运作 方式 ,形成 整个 产业 链 的 重 塑 融合 , 带 来 新 的 客户 群体 ,改变 生 
产 要 素 获 取 方 式 ,提高 行业 竞争 力 。 

(2) 创新 驱动 。 中 国 需要 从 粗放 的 资源 驱动 型 增长 转变 成 精细 的 创新 驱动 型 发 展 模 
式 。“ 互 联网 +" 可 以 使 网 络 模式 下 的 行业 更 容易 进行 二 度 创新 ,也 能 通过 互联 网 创新 为 
行业 带 来 效率 的 提升 ,驱动 行业 增长 。 

(3) 重 逆 结构。 行业 和 社会 的 互联 网 化 可 能 打破 原 有 的 社会 结构 .经 济 结构 .地缘 结 
构 和 文化 结构 。 在 “互联 网 + "框架 下 ,许多 传统 的 结构 都 可 能 有 所 变化 。 

(4) 尊重 人 性 。 人 是 互联 网 的 体验 者 和 使 用 者 ,互联 网 的 力量 也 体现 为 对 人 性 的 尊 
重 ,特别 是 在 Web 2.0 时 代 , 用 户 不 仅 是 互联 网 的 客户 和 消费 群体 ,也 是 网 络 内 容 的 来 
源 , 在 “互联 网 + "时 代 更 加 需要 尊重 和 了 解 人 性 。 

(5) 开放 生态 。“ 互 联网 + "的 生态 是 开放 的 ,将 孤岛 式 的 传统 方式 和 制约 创新 的 环 
节 打 开 , 连 接 起 来 ,使 研发 由 市 场 驱动 ,让 真正 的 需求 决定 行业 的 价值 。 


1.2.2 “互联 网 + 的 应 用 


现在 的 互联 网 已 经 不 再 是 一 个 独立 的 行业 特别 是 智能 手机 的 普及 使 移动 互联 网 打破 
了 生活 与 网 络 的 分 隔 , 线 上 和 线 下 的 界限 ,与 其 他 行业 结合 变 成 了 底层 的 框架 。 现 阶段 我 
国 的 “互联 网 +” 主要 有 如 下 应 用 方向 。 

(1) 互联 网 + 工业 。 传 统制 造 企 业 采 用 信息 通信 技术 改造 原 有 产品 及 研发 生产 方 
式 。2014 年 ,中 国 互联 网 协会 和 工业 应 用 委员 会 等 国家 级 产业 组 织 宣告 成 立 , “工业 互联 
网 "已 经 开始 实践 。 传 统 工业 与 移动 互联 网 . 云 计算 , 物 联网 和 互联 网 商业 模式 等 网 络 创 
新 技术 融合 后 ,产生 了 一 大 批 新 式 产品 。 

(2) 互联 网 + 商贸 。 商 贸 领域 与 互联 网 融合 的 时 间 较 早 , 电 子 商 务 业务 多 年 来 伴随 
着 我 国 互联 网 行业 壮大 ,目前 仍 处 于 快速 发 展 阶段 ,覆盖 了 包括 B2B 电子 商务 .企业 自 营 
电 商 .出 口 跨 境 电 商 等 多 种 贸易 类 型 ,产生 了 一 大 批 电 子 商 务 平台 。 随 着 移动 互联 网 的 出 
现 ,这 个 方向 也 面临 着 转型 升级 ,发展 前 景 广阔 。 

(3) 互联 网 + 金融。 在 稳定 的 金融 领域 , 随 着 余额 宝 的 横 空 出 世 , 开 始 出 现 变化 , 国 
家 对 互联 网 金融 的 研究 越 来 越 透彻 ,互联 网 金融 得 到 了 有 序 的 发 展 以 及 相关 政策 的 支持 
和 鼓励 。 出 现 了 以 在 线 理 财 支付 . 电 商 小 贷 、P2P、 众 筹 等 为 代表 的 细 分 互联 网 金融 模式 ， 
互联 网 金融 已 然 成 为 一 个 新 金融 行业 ,并 为 普通 大 众 提供 了 更 多 元 化 的 投资 理财 选择 。 

(4) 互联 网 + 教育 。 在 中 国教 育 领域 ,“ 互 联网 +" 意 味 着 教育 内 容 的 持续 更 新 、 教 
育 方式 的 不 断 变 化 教育 评价 的 多 样 化 。 互 联网 和 课程 结合 带 来 了 各 学 科 课程 内 容 全 面 
拓展 与 更 新 ,使 得 知识 更 加 多 样 化 ;互联 网 和 教学 结合 形成 了 网 络 教学 平台 .软件 .视频 等 
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诸多 全 新 的 概念 ,使 传统 的 教学 组 织 形式 发 生 了 革命 性 变化 ;互联 网 和 学 习 结 合 创造 了 移 
动 学 习 平台 ,代表 的 是 学 生 学 习 观 念 与 行为 方式 的 转变 。 未 来 的 教 与 学 活动 都 会 围绕 互 
联网 进行 ,而 线 下 活动 则 成 为 线 上 活动 的 补充 与 拓展 。 

(5) 互联 网 + 民生 。 在 民生 领域 ,不 论 是 行政 事务 还 是 民生 服务 都 正在 向 互联 网 敞 
开 大 门 。 在 各 级 政府 或 事业 单位 网 站 上 可 以 查找 到 多 种 在 线 服 务 ,移动 电子 政务 可 能 成 
为 推进 国家 治理 体系 的 工具 。 越 来 越 多 的 打车 软件 ,水 电费 提交 接口 和 在 线 订 票 平台 可 
以 使 人 们 的 出 行 更 加 便捷 。 互 联网 的 应 用 将 使 人 们 的 生活 变 得 更 加 智能 。 


1.3 网 站 的 工作 原理 


在 “互联 网 + "的 大 背景 下 ,将 出 现 更 多 面向 各 行 各 业 的 网 站 。 访 问 网 站 实际 上 就 是 
网 页 服务 器 与 客户 端 浏 览 器 交互 的 过 程 ,浏览 器 是 运行 在 客户 端 发 送 请 求 并 显示 结果 的 
软件 ,网 页 服务 器 程序 是 工作 在 网 站 主机 上 响应 请 求 并 提供 文档 的 软件 ,两 者 通过 超 文本 
传输 协议 (Hypertext Transfer Protocol，HTTP ) 规定 的 流程 和 通信 协议 进行 通信 。 网 站 的 
工作 原理 如 图 1-3 所 示 。 
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图 1-3 网 站 工作 原理 


浏览 器 首先 发 送 HTTP 请 求 , 通 过 HTTP 协议 的 统一 资源 定位 器 ( Uniform Resource 
Locator，URL) 与 网 页 服务 器 通信 。 统 一 资源 定位 器 ,也 称 资源 名 ,是 互联 网 上 资源 访问 
地 址 和 访问 方式 的 标准 表示 。 使 用 资源 名 可 以 访问 存储 在 服务 器 中 的 数据 文件 或 者 要 求 
执行 服务 器 中 的 网 络 应 用 程序 ,并 将 执行 结果 返回 到 客户 机 。 

网 页 服务 器 运行 在 网 站 后 台 ,主要 任务 是 监听 主机 通信 端口 接 和 的 网 络 请 求 。 当 接 
收 到 HTTP 请 求 时 ,网 页 服务 器 通过 解析 资源 名 ,在 网 站 的 文件 系统 中 定位 所 需 文件 。 若 
定位 成 功 , 则 返回 请 求 的 网 页 信息 ;和 否则 ,在 浏览 器 中 显示 异常 信息 及 状态 码 。 例 如 : 404 
表示 请 求 的 资源 不 存在 ,503 表示 服务 器 过 载 而 无 法 访问 等 。 

如 果 用 户 请 求 访问 的 是 静态 网 页 , 则 网 页 服务 器 直接 将 静态 网 页 发 送 到 客户 端 浏览 
器 ;如 果 是 动态 网 页 , 则 网 页 服务 器 通过 语言 解释 程序 执行 文件 中 的 脚本 代码 ,并 连接 数 
据 库 服务 器 ,实现 网 页 的 业务 逻辑 ,生成 浏览 器 可 识别 格式 。 最 后 ,网 页 服务 器 负责 将 网 
页 回 传 给 客户 端 ,再 通过 浏览 器 解释 并 显示 网 页 。 

【 例 1.1】 使 用 下 浏览 器 访问 百度 网 站 ,观察 访问 网 站 动态 网 页 的 效果 。 
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(1) 启动 下 浏览 器 ,输入 资源 名 http://www. baidu. com 访问 百度 网 站 ,浏览 器 会 向 
百度 服务 器 发 送 通 信 请 求 。 

(2) 百度 服务 器 获取 到 用 户 请 求 后 ,解析 资源 名 并 显示 主页 ,查找 并 准备 相关 文件 ， 
以 HTTP 协议 的 形式 发 送 给 用 户 浏览 器 。 用 户 在 浏览 器 中 按 Fl12 可 以 打开 “开发 人 员工 
有 具 "窗口 ,在 “网 络 " 选 项 卡 中 可 以 查看 浏览 嚣 发送 和 接受 的 消息 内 容 ,例如 ,通信 请 求 的 
资源 名 ,获取 方法 ,格式 和 状态 码 等 。 

(3) 浏览 器 接收 并 解析 网 页 源 文件 后 ,按照 HTML 标签 功能 组 织 网 页 所 需 资 源 ,并 显 
示 当 前 页 面 。 从 浏览 器 的 右 击 快捷 菜单 中 选择 “查看 源 文件 "选项 ,可 以 看 到 服务 器 向 浏 
览 器 传输 的 HTML 代码 。 

(4) 在 百度 主页 的 搜索 栏 中 输入 “网 站 建设 " ,观察 “开发 人 员工 具 "窗口 发 现 : 浏览 
器 向 百度 服务 器 发 送 新 的 HTTP 请 求 。 服 务 器 端 通过 语言 解释 程序 执行 动态 主页 中 的 应 
用 程序 并 检索 数据 库 , 生 成 新 的 页 面 和 状态 码 回 传 给 用 户 浏 览 器 。 随 着 用 户 请 求 的 改变 ， 

结构 和 内 容 随 之 发 生变 化 ,实时 显示 当前 关键 字 的 搜索 结果 ,如 图 14 所 示 。 
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1.4 网 站 建设 的 相关 软件 和 技术 


网 站 建设 是 一 个 广义 的 术语 ,涵盖 了 网 站 规划 ,域名 申请 主机 租赁 ` 网 页 设计 、 网 络 
应 用 程序 开发 .推广 应 用 和 维护 等 多 方面 知识 和 技术 。 本 节 以 建设 人 才 招 聘 网 站 为 例 , 概 
要 介绍 网 站 建设 中 涉及 的 软件 技术 。 


1.4.1 网 站 的 常用 软件 


网 站 通过 各 种 服务 器 软件 为 用 户 提供 网 络 访问 服务 ,其 中 最 重要 的 软件 是 网 页 服务 
器 和 数据 库 服务 器 。 网 页 服务 器 为 用 户 提供 网 上 信息 浏览 和 文件 下 载 服务 ,可 根据 网 站 
应 用 的 需要 ,部署 动态 网 页 程序 的 解释 环境 。 数 据 库 服务 器 为 网 页 提供 数据 支持 ,如 人才 
招聘 网 站 中 的 招聘 公司 .职位 .求职 人 员 和 管理 人 员 等 数据 。 


1. 网 页 服务 器 软件 


网 页 服务 器 也 称 为 Web 服务 器 或 HTTP 服务 器 。 目 前 世界 上 最 流行 的 三 大 网 页 服 
务 器 是 IIS .Nginx 和 Apache。 

(1) Microsoft IIS 服务 器 : 是 专用 于 Windows 操作 系统 的 网 上 信息 发 布 服务 器 ,属于 
Windows 的 内 部 组 件 ,兼容 包括 ASP 语言 在 内 的 微软 各 项 Web 技术 。IIS 服务 器 功能 强 
大 ,运行 稳定 ,是 常见 的 网 页 服务 器 软件 。 

(2) Nginx 服务 器 : 是 一 款 轻 量 级 服务 器 ,可 提供 网 页 服务 和 电子 邮件 服务 。 其 特点 
是 高 性 能 ,系统 资源 消耗 少 ,并 发 能 力 强 。 由 于 开放 源 代码 ,表现 性 能 好 ,近年 来 在 服务 器 
市 场 的 占有 率 逐 步 提高 。 

(3) Apache 服务 器 : 是 使 用 率 排名 第 一 的 Web 服务 器 软件 ,几乎 可 以 运行 在 所 有 的 
计算 机 平台 上 。Apache 服务 器 快速 .可靠 ,可 通过 简单 的 扩充 ,部 署 多 种 解释 程序 ,并 可 
作为 代理 服务 器 使 用 。 


2. 数据 库 管理 系统 


有 许多 数据 库 管 理 系 统 ( Data Base Management System ,DBMS ) 软件 可 为 网 站 提供 数 
据 服务 ,每 个 网 站 都 应 该 安装 数据 库 管 理 系 统 。 

(1) Oracle 数据 库 : 是 目前 比较 流行 的 C/S 或 B/S 结构 的 大 型 数据 库 管 理 系 统 , 功 
能 强大 ,技术 性 强 ,适合 大 型 网 络 系统 。 

(2) DB2 数据 库 : 可 以 工作 在 不 同 的 操作 系统 平台 ,具有 较 好 的 可 伸缩 性 ,支持 大 型 
机 到 微型 计算 机 环境 ,主要 应 用 于 大 型 网 络 系统 。 

(3) Access 数据 库 : 只 能 运行 于 Windows 系统 ,具有 Microsoft Jet 数据 引擎 和 图 形 用 
户 界面 两 个 特点 ,是 office 软件 组 之 一 ,适用 于 工作 在 C/S 结构 的 小 型 应 用 系统 。 

(4) SQL Server 数据 库 : 主要 运行 在 Windows 平台 ,面向 大 型 网 络 系统 。 
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(5) MySQL 数据 库 : 是 小 型 数据 库 管 理 系统 ,体积 小 .速度 快 .成 本 低 而 且 开放 源码 ， 
被 许多 中 小 型 网 站 选用 。 


1.4.2 网 页 应 用 程序 分 类 


用 户 在 浏览 器 看 到 的 网 页 信息 ,一 般 是 由 HTML、 层 一样 式 表 ( Cascading Style Sheets， 
CSS) 和 其 他 脚本 语言 编写 的 网 页 程序 运行 的 结果 。 

HTML 是 一 种 描述 网 页 信息 的 标记 性 语言 ,通过 HTML 标签 向 浏览 器 指明 网 页 中 的 
文字 图片 .链接 ,动画 ,表格 和 列表 等 各 种 元 素 的 内 容 、 样 式 和 布局 ,是 网 页 应 用 程序 的 设 
计 基础 。 

CSS 是 目前 公认 的 网 页 页 面 排版 样式 标准 ,作为 HTML 语言 的 一 种 补充 ,帮助 HTML 
实现 样式 和 内 容 的 分 离 ,使 网 页 的 编写 和 维护 更 方便 。 

HTML 和 CSS 作为 标记 性 语言 ,只 能 用 于 描述 网 页 中 的 元 素 ,不 能 进行 事务 处 理 和 他 
辑 判断 。 当 涉及 特殊 效果 和 动态 内 容 时 ,需要 借助 脚本 语言 设计 网 页 脚本 程序 。 根 据 网 
页 脚本 程序 执行 的 位 置 ,网 页 应 用 程序 可 以 分 为 客户 端 程序 和 服务 器 端 程序 。 


1. 客户 端 程序 


客户 端 程序 主要 指 在 客户 浏览 器 上 运行 的 脚本 程序 ,通常 使 用 HTML 和 CSS 设计 显 
示 界 面 , 通 过 客户 端 脚 本 语言 实现 逻辑 处 理 , 使 网 页 能 响应 用 户 操作 ,动态 显示 页 面 ,检测 
浏览 器 和 实现 各 种 特殊 效果 。 客 户 端 程序 完全 由 浏览 器 运行 ,不 需要 服务 器 和 数据 库 支 
持 ,降低 网 络 通信 和 服务 器 负载 ,提高 网 站 整体 性 能 ,但 不 能 自动 改变 网 页 内 容 , 常 用 于 设 
计 静 态 网 页 。 

常见 的 客户 端 脚本 语言 有 JavaScript 和 VBScript, 其 中 JavaScript 编程 简单 ,功能 强大 
并 支持 跨 平 台 ,得 到 所 有 浏览 器 的 支持 ,已 成 为 客户 端 脚本 的 标准 ,广泛 用 于 Web 应 用 程 
序 开 发 。 

客户 端 程序 可 以 手工 编写 代码 ,也 可 以 借助 Dreamweaver( 简称 DW ) 和 FrontPage 等 
可 视 化 网 页 设计 工具 ,通过 键盘 和 鼠标 的 简单 操作 自动 生成 客户 端 程序 代码 。 如 
Dreamweaver 中 的 “行为 "可 以 用 于 创建 动态 效果 ,比较 适合 非 专 业 人 员 。 


2. 服务 器 端 程序 


服务 器 端 程序 主要 承担 服务 器 端的 数据 维护 .业务 规划 和 管理 等 任务 ,主要 操作 由 动 
态 网 页 完成 。 要 改变 静态 网 页 中 的 内 容 , 也 需要 在 服务 器 端 修改 和 发 布 网 页 源 文件 。 例 
如 ,开发 聊天 室 、 留 言 板 和 BBS 等 实时 更 新 的 网 页 ,需要 在 服务 器 端 进 行 设计 和 维护 
网 页 。 

目前 常见 的 服务 器 端 脚本 语言 有 ASP、JSP 和 PHP。 

(1) ASP: 是 动态 网 页 技术 标准 ,支持 VBScript 和 JavaScript 脚本 ,通常 只 与 IIS 一 起 
使 用 ,具有 良好 的 性 能 ,但 跨 平 台 能 力 不 足 。 

(2) JSP: 内 置 基 于 Java 的 脚本 语言 ,支持 Apache 服务 器 ,可 以 完成 功能 强大 的 跨 平 
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台 站 点 程序 。 
(3) PHP: 是 一 种 跨 平 台 的 服务 器 端 脚本 语言 ,支持 目前 绝 大 多 数 数据 库 和 服务 器 ， 
并 且 开 放 源 代码 ,适合 中 小 型 网 站 的 动态 网 页 设计 。 


1.5 Apache 服务 器 的 安装 与 测试 


Apache 是 Web 服务 器 软件 ,可 以 运行 在 几乎 所 有 平台 的 计算 机 中 。 在 计算 机 上 运行 
Apache 软件 之 前 ,需要 下 载 .安装 和 配置 Apache 服务 器 软件 。 


1.5.1 下 载 Apache 服务 器 软件 


Apache 软件 版 本 更 新 的 速度 较 快 ,在 其 官方 网 站 中 可 以 下 载 最 新 版 本 或 某 一 稳定 的 
前 期 版 本 。 在 网 络 浏览 器 网 址 栏 中 输入 http://httpd. apache. org ,在 网 站 首页 中 阅读 版 本 
概况 , 单 击 DownLoad 超 链接 转 到 下 载 页 面 。 

在 下 载 页 面 中 , 网 站 为 当前 版 本 提供 了 几 种 下 载 类 型 , 单 击 Files for Microsoft 
Windows 超 链 接 , 可 下 载 Windows 直接 运行 的 文件 。 

也 有 许多 第 三 方 镜像 平台 提供 了 Apache 软件 下 载 ,如 http://www. apachehaus. com 
站 点 。 打 开 下 载 页 面 后 ,找到 并 下 载 服务 器 压缩 文件 HTTPD-2. 4. 17-x86. ZIP, 其 中 x86 
代表 32 位 系统 ,如 果 需 要 64 位 系统 , 则 选择 x64 版 本 。 


1.5.2 ”安装 与 印 载 Apache 服务 器 软件 


安装 与 卸载 Apache 服务 器 软件 的 步骤 如 下 : 

(1) 解压 缩 。 将 文件 解压 缩 到 本 机 指定 的 服务 器 文件 夹 ,如 D: \server\Apache24 ,并 
修改 Apache 服务 器 配置 文件 ,为 安装 程序 指定 服务 器 文件 夹 位置 。 

(2) 修改 配置 文件 。 用 记事 本 打开 D: \server\Apache24 \conf\httpd. conf 的 Apache 
配置 文件 , 按 Ctrl +F 键 打开 查找 对 话 框 ,搜索 ServerRoot ,将 其 值 修改 为 本 机 服务 器 文件 
夹 的 路 径 ,如 ServerRoot "D: \server\Apache24" 。 

(3) 安装 软件 。 单 击 Windows 的 “开始 "按钮 ,在 “开始 "下 面 的 搜索 框 中 输入 CMD 
并 按 Enter 键 ， 打开 命令 提示 符 窗口 。 输 入 命令 DD: \server \ Apache24 \ bin \ httpd. exe -k 
install -n apache 并 按 Enter 键 ( 即 常 说 的 回 车 ) ,开始 安装 Apache 服务 器 软件 。 安 装 成 功 
后 ,将 服务 名 称 命名 为 Apache ,系统 自动 测试 , 若 有 问题 ,系统 将 提示 错误 信息 。 图 1-5 表 
示 安 装 成 功 。 

(4) 印 载 软件 。 要 印 载 Apache 软件 ,需要 先 印 载 Apache 服务 。 在 命令 提示 符 窗口 
中 输入 命令 scdelete apache ,最 后 删 除 服 务 器 文件 夹 就 能 实现 软件 印 载 。 
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图 1-5 正确 安装 Apache 服务 


1.5.3 ”启动 和 配置 Apache 服务 器 


安装 好 Apache 服务 器 后 ,配置 相关 的 端口 参数 ,开启 或 关闭 服务 器 。 

(1) 启动 和 关闭 Apache 服务 器 。 双 击 D: \Server\Apache2. 4\Bin\ApacheMonitor. 
EXE 文件 运行 服务 器 监控 程序 ,再 双击 任务 栏 中 对 应 的 图 标 , 打 开 监 控 器 窗口 。 

在 服务 状态 栏 中 选择 已 安装 的 Apache 服务 , 单 击 Start 按钮 , 便 启动 了 Apache 服务 
器 。 如 正确 启动 , 则 Apache 左 侧 图 标 变 为 绿灯 。 单 击 Stop 按钮 将 关闭 Apache 服务 器 ; 单 
击 Restart 按钮 ,将 重启 Apache 服务 器 

(2) 配置 端口 参数 。Apache 服务 器 无 法 正常 启动 的 通常 原因 是 Apache 与 其 他 网 络 
程序 的 端口 号 冲突 。 解 决 的 方法 是 : 用 记事 本 打开 Apache 服务 器 的 配置 文件 httpd. 
conf ,将 Listen 80 项 的 参数 值 80 改 为 其 他 端口 号 ,如 8082 

(3) 辅助 功能 。 单 击 Services 按钮 ,打开 Windows 系统 的 服务 管理 窗口 ,可 查看 和 设 
置 相关 服务 的 状态 ; 单 击 Connect 按钮 ,可 以 实现 远程 连接 ,通过 在 对 话 框 中 输入 对 方 主 
机 的 名 称 或 IP 地 址 ,实现 两 个 主机 之 间 的 通信 


1.5.4 测试 Apache 服务 器 软件 


Apache 服务 器 的 主要 功能 是 为 客户 端 提供 网 页 链接 服务 , 当 客 户 端 向 服务 器 申请 某 
个 有 效 网 页 时 ,服务 器 将 网 页 回 传 给 客户 端 浏览 器 ,这 些 可 访问 的 网 页 默认 存放 在 
Apache 安装 目录 下 的 HTDOCS 文件 夹 中 。 如 果 客 户 端 在 网 络 浏览 器 网 址 栏 中 仅 输 入 服 
务 器 站 点 域名 或 IP 地 址 ,而 未 指定 所 访问 的 具体 网 页 , 则 HTDOCS 文件 夹 中 的 index. 
html 文件 默认 作为 网 站 主页 反馈 给 客户 端 , 所 以 通常 将 网 站 的 主页 命名 为 index. html 
文件 。 

浏览 器 和 服务 器 的 交互 过 程 可 以 通过 回路 地 址 localhost 查看 。 回 路 地 址 localhost 是 
一 个 标准 主机 名 ,对 应 的 地 址 为 127.0.0.1, 访 问 localhost 表示 访问 本 机 服务 器 站 点 ， 
通常 用 作 单 机 情况 下 的 服务 器 测试 。 

【 例 1.2】 测试 Apache 服务 器 的 运行 。 

(1) 双击 任务 栏 中 Apache 服务 器 图 标 ,打开 监控 器 界面 , 单 击 Start 按钮 启动 Apache 
服务 
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(2) 打开 下 浏览 器 ,输入 回路 地 址 http ://localhost , 若 出 现 如 图 1-6 所 示 的 服务 器 测 
试 页 面 (版 本 或 下 载 源 不 同 ,测试 页 面 有 差异 ) , 则 表示 服务 器 正确 运行 。 

(3) 打开 Apache 安装 目录 下 的 HTDOCS 文件 夹 ,双击 测试 页 面 文件 index. html, 显 
示 的 网 页 应 与 图 1-6 所 示 网 页 相同 。 











[TT PD OO ipeehe ms nisuinei ， x 





ApPpache Hanis 


Apache™ binarles for Windows® Readme First 





Welcome, 
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RW experiencing problems, or is undergoing routine maintenance. 
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图 1-6 Apache 服务 器 的 测试 页 面 


1.6 MySQL 数据 库 管理 系统 的 安装 与 测试 


MySQL 具有 体积 小 、 速 度 快 源 代码 开放 和 使 用 成 本 低 等 特点 ,是 中 小 型 网 站 常用 的 
关系 型 数据 库 管理 系统 


1.6.1 MySQL 数据 库 管理 系统 的 下 载 


MySQL 数据 库 软 件 对 用 户 采 用 双 授 权 政 策 , 分 为 社区 版 (Community Server) 和 企业 
版 (Enterprise Server) 。 社 区 版 开源 且 完 全 免费 ,但 缺乏 官方 的 技术 支持 ;企业 版 提供 了 更 
全 面 的 功能 ,管理 工具 和 技术 支持 。 如 果 从 成 本 考虑 , 仅 使 用 社区 版 配合 PHP 和 Apache 
也 能 构建 性 能 卓越 的 开发 环境 。 

在 浏览 器 中 输入 MySQL 的 官方 网 站 http://dev. mysql. com/ downloads, 进入 网 页 , 选 
择 社区 版 5.7.9, 下 载 软件 安装 包 。 


1.6.2 MySQL 数据 库 管理 系统 的 安装 


解压 缩 下 载 到 本 地 的 安装 文件 ,通过 如 下 步骤 安装 MySQL 软件 : 

(1) 双击 MySQL-installer-community-5.7.9.1. msi 安装 程序 ,出 现 MySQL 的 安装 向 导 
窗口 。 单 击 Install MySQL Products 按钮 ,弹出 用 户 的 许可 证 协议 界面 。 

(2) 选中 Iaccept the license terms 前 面 的 复 选 框 ,表示 接受 用 户 安装 时 的 许可 证 协 
议 ,然后 单 击 Next 按钮 ,进入 查找 最 新 版 本 界面 。 





第 1 章 ”网 站 环境 设计 基础 


(3 





(3) 选择 Skip the check for updates 选项 跳 过 更 新 检查 ,可 以 根据 具体 情况 操作 , 单 和 
Execute 按钮 ,进入 安装 类 型 设置 界面 。 

(4) MySQL 提供 了 5 种 安装 类 型 : Developer Default( 默认 安装 类 型 ) ,Server only( 仅 
作为 服务 器 ) ,Client only( 仅 作为 客户 端 ) ,Full( 完 全 安装 类 型 ) ,Custom( 自 定义 安装 类 
型 ) 。 这 里 可 以 直接 选择 Developer Default ,用户 也 可 以 根据 实际 情况 对 数据 库 做 更 多 设 
定 , 单 击 Next 按钮 后 弹出 安装 条 件 检查 界面 。 

(5) 数据 库 软 件 要 正确 运行 需要 多 种 相关 软件 支持 ,安装 条 件 检查 界面 用 于 保证 数 
据 库 运行 所 需 软件 正确 安装 。 计 算 机 一 般 不 安装 C ++ 相关 程序 ,可 能 需要 在 此 下 载 并 安 
装 。 单 击 Next 按钮 ,进入 安装 界面 。 

(6) 单 击 Execute 按钮 ,开始 安装 程序 。 当 安装 完成 之 后 单 击 Next 按钮 ,进入 服务 器 
配置 页 面 , 对 服务 器 进行 个 性 化 设置 。 

(7) 在 第 一 配置 页 中 ,通过 Server Configuration Type 下 面 的 Config Type 下 拉 列 表 项 
可 以 配置 服务 器 的 类 型 : Developer Machine (开发 机 器 ) ,Server Machine (服务 器 ) 和 
Dedicated MySQL Server Machine( 专用 MySQL 服务 器 ) 。 不 同 的 服务 器 类 型 对 应 数据 库 
对 内 存 .硬盘 等 资源 的 不 同 决策 。 通 过 Enable TCP/IP Networking 左边 的 复 选 框 可 以 启用 
或 禁用 TCP/IP 网 络 ,并 配置 用 于 连接 MySQL 服务 器 的 端口 号 。 

新 建 一 个 网 站 数据 库 , 采 用 默认 的 Developer Machine 类 型 ,启用 TCP/IP 网 络 ,采用 
默认 端口 3306 即 可 ,如 图 1-7 所 示 。 


Er 


MySQL. Installer Type and Networking 


Server Configuration Type 


Choose the correc 
define how much 






ntypefor this MySQL Server installation. This setting will 
assigned to the MySQL Serverinstance 





Config Type 3 - 
Connectivity 
Use the following controls to select how you would like to connect to this server, 
Tep/p Port Number 3306 
Open Firewall port for network access 
加 Named Pipe Pipe Name |MYSQL 
Shared Memory Memory Name = MYSQL 





get additional configuration page where you can set advanced 
e 








图 1-7 服务 器 类 型 配置 


(8) 在 第 二 配置 页 中 ,通过 MySQL Root password (输入 新 密码 ) 和 Repeat Password 
(确认 密码 ) 可 以 设置 root 用 户 的 密码 。root 用 户 是 MySQL 数据 库 中 唯一 的 超级 管理 员 ， 
有 具有 等 同 于 操作 系统 的 最 高 级 权限 , 却 不 适合 日 常 的 数据 库 管 理工 作 , 可 以 通过 下 面 的 
Add User 按钮 添加 新 的 普通 管理 员 用 户 , 如 图 1-8 所 示 。 

(9) 继续 单 击 Next 按钮 ,完成 MySQL 数据 库 的 整个 安装 配置 工作 。 
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图 1-8 服务 器 用 户 配置 


1.6.3 ”MySQL 数据 库 管 理 系统 的 测试 


MySQL 数据 库 分 为 客户 端 和 服务 器 两 部 分 , 当 服 务 器 端 服务 开启 时 ,才能 通过 客户 
端 登录 数据 库 ,并 对 数据 库 进 行 操作 。 


1. 启动 数据 库 服务 


在 MySQL 数据 库 安装 过 程 中 ,一 般 将 MySQL 服务 设置 为 自动 启动 , Windows 系统 中 
可 以 通过 “服务 "窗口 对 数据 库 服务 手动 修改 。 

单 击 “ 开 始 "菜单 按钮 ,在 命令 搜索 栏 里 输入 services. msc 后 按 Enter 键 打开 “服务 ” 
窗口 。 在 “服务 "窗口 中 可 以 找到 MySQL57 服务 , 右 击 该 服务 ,在 快捷 菜单 中 选择 “属性 ” 
命令 ,打开 服务 的 属性 窗口 。 

在 属性 窗口 里 可 以 更 改 MySQL 服务 的 状态 : 启动 ,停止 暂停 和 恢复 ,也 可 以 设置 服 
务 的 启动 类 型 : 自动 .手动 和 已 禁用 ,如 图 1-9 所 示 。 

由 于 MySQL 服务 器 端 不 提供 图 形 界面 ,因此 想 知道 MySQL 服务 是 否 运行 ,可 以 在 
Windows 任务 管理 器 中 查看 是 否 存在 MySQLd. exe 进程 。 


2. 登录 数据 库 


在 MySQL 服务 启动 后 ,可 以 通过 在 命令 行 客户 端 中 输入 控制 命令 ,登录 和 操作 数据 
库 服务 器 。 单 击 Windows 开始 "菜单 一 “所 有 程序 "一 MySQL 一 MySQL 5. 7 一 MySQL 
Command Line Client ,打开 MySQL 的 命令 行 客户 端 程序 。 

MySQL 命令 行 客 户 端 也 称 为 控制 台 。 初 次 登录 需要 在 控制 台中 输入 安装 时 设 定 的 
超级 管理 员 密 码 , 即 root 用 户 密码 ,并 按 Enter 键 登录 。 如 果 成 功 ,控制 台 以 root 用 户 身 份 
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文件 (所作 (A) 查看 M) 帮助 (H) 
名 中国 目 下 村 | 目 中 | ”四 让 
志和 体 地 5 
刘 秽 
服务 名 称 ; SOLS 
售 止 此 服务 显示 名 称 SQLST 
置信 此 服务 i 
重合 动 此 服务 i 
可 执行 文件 的 路径 
“C:\Program Files\NySQL\NySQL Server 5.T\bin\nysqld exe” 一 
i 的 上 
服务 村 态 a 
BE) 停止 IC) | 暂停 中) [| 恢 槛 @) ] 
当 从 此 处 启动 服务 时 ， 您 可 指定 所 适用 的 启动 可 数 。 
启动 区 数 0) [5 
[| LD) we 
移 Network Store L， 此 服 .。 已 启动 自动 本 地 服务 
扩展 人 村 全 

















图 1-9 ”MySQL 服务 的 属性 窗口 


登录 到 MySQL 数据 库 , 并 显示 欢迎 语句 和 当前 服务 器 的 状态 。 此 时 在 控制 台中 出 现 命 令 
行 提示 符 “ MySQL >” ,提醒 用 户 输入 MySQL 支持 的 命令 。 


3. 操作 数据 库 


使 用 任意 身份 登录 MySQL 数据 库 后 ,就 可 以 通过 控制 台 在 当前 用 户 权 限 下 对 数据 库 
执行 操作 和 查看 结果 。MySQL 数据 库 提 供 了 多 个 工具 程序 辅助 用 户 查 看 数据 库 服务 器 
状态 和 做 基本 的 管理 ,下 面 列 出 一 些 常用 工具 的 调用 命令 。 

MySQL: 用 于 MySQL 对 SQL 的 解释 器 工具 ,可 用 于 登录 开启 ,关闭 服务 器 。 

MySQLaccess: 用 于 管理 用 户 的 访问 接口 ,检查 访问 权限 。 

MySQLadmin: 用 于 管理 数据 库 服务 器 的 接口 程序 ,包括 数据 库 的 创建 、 移 除 .授权 和 
刷新 等 多 种 管理 功能 。 

MySQLcheck: 用 于 检查 表 的 完整 性 并 修复 检测 到 的 错误 。 

MySQLdump: 用 于 将 数据 库 或 表 转 储 为 男 一 文件 。 

MySQLhotcopy: 用 于 当 服 务 器 运行 时 对 数据 库 进 行 热 备份 。 

MySQLimport: 用 于 将 不 同文 件 格式 的 数据 导入 到 MySQL 表 中 。 

MySQLshow: 用 于 显示 服务 器 或 者 所 包含 数据 库 和 表 的 信息 。 

perror: 用 于 显示 指定 的 错误 代码 含义 。 

这 些 命令 的 格式 和 使 用 方法 可 以 在 控制 台中 通过 输入 Help 命令 查看 。 

MySQL 作为 关系 型 数据 库 软 件 ,对 数据 的 查询 更 新 和 管理 采用 的 是 通用 的 数据 库 
查询 语言 SQL, 通 过 在 控制 台 直接 输入 SQL 命令 实现 。 

【 例 1.3】 在 控制 台中 运行 SQL 命令 。 
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在 控制 台中 输入 以 下 SQL 命令 ,获取 当前 数据 库 用 户 列 表 。 


mysql MWsemysql; 
mysql] >Select * From User; 


1.7 常见 MySQL 可 视 化 管理 工具 


MySQL 作为 一 个 命令 驱动 的 数据 库 管理 系统 ,通过 在 控制 台 输入 命令 操作 数据 不 仅 
不 直观 ,而 且 对 用 户 的 SQL 熟悉 度 要 求 较 高 。 为 此 出 现 了 许多 能 管理 MySQL 数据 库 的 可 
视 化 管理 工具 ,能 够 比 命令 行 界面 更 方便 地 操作 数据 库 。 


1.7.1 常用 管理 工具 介绍 


为 MySQL 数据 库 提供 图 形 界 面 的 软件 有 很 多 ,常用 的 是 PHPMyAdmin 、Navicat、 
MySQL GUI Tools 等 。 每 种 可 视 化 管理 工具 都 有 其 特点 。 


1. PHPMyAdmin 


PHPMyAdmin 简称 PMA ,是 使 用 PHP 语言 编写 的 ,基于 Web 方式 架构 在 服务 器 主机 
上 的 数据 库 图 形 管理 工具 。 它 采用 了 B/S 模式 , 跟 其 他 PHP 程序 一 样 可 以 在 任意 计算 机 
的 浏览 器 中 连接 和 操作 MySQL 数据 库 , 得 到 了 众多 网 站 开发 人 员 的 青睐 。 由 于 
PHPMyAdmin 易于 远程 管理 , 且 完 全 免费 ,已 成 为 MySQL 数据 库 最 常用 的 维护 工具 。 


2. Navicat 


Navicat 是 一 套 世 界 知名 的 桌面 版 数据 库 管理 工具 ,提供 多 种 语言 选择 ,支持 对 本 地 
或 远程 的 MySQL、SQL Server ,Oracle 等 多 种 数据 库 进 行 管理 及 开发 。Navicat 的 功能 足以 
满足 专业 开发 人 员 的 所 有 需求 ,包含 数据 模型 数据 传输 数据 同步 和 创建 报表 及 计划 等 
多 种 数据 库 工 具 , 使 用 可 靠 ,运行 快速 且 价 格 适 宜 ,并 提供 可 用 的 免费 版 本 ,专门 用 于 简化 
数据 库 管 理 和 降低 管理 成 本 。 


3. MySQL GUI Tools 


MySQL GUI Tools 是 一 个 由 MySQL 官方 提供 的 可 视 化 的 MySQL 数据 库 管理 控制 台 ， 
目前 不 支持 中 文 ,主要 包含 4 个 用 于 数据 管理 的 图 形 化 工具 。 

(1) MySQL Migration Toolkit: 用 于 实现 不 同 数据 库 之 间 数 据 迁 移 的 工具 。 

(2) MySQL Administrator: 用 于 服务 器 端 对 MySQL 服务 进行 管理 的 工具 。 

(3) MySQL Query Browser: 是 MySQL 数据 查询 界面 ,用 于 在 客户 端 进行 数据 查询 、 
创建 和 管理 的 工具 。 

(4) MySQL Workbench: 是 专 为 MySQL 设计 的 数据 库 建 模 工具 ,可 用 于 设计 和 创建 
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新 的 数据 库 图 示 ,建立 数据 库 文档 ,进行 复杂 的 数据 库 迁 移 。 
下 面 分 别 介绍 基于 Web 的 PHPMyAdmin 软件 和 支持 多 种 数据 库 的 桌面 型 Navicat 软 
件 的 安装 和 配置 。 


1.7.2 ”PHPMyAdmin 的 安装 与 启动 


1. PHPMyAdmin 的 下 载 

在 官方 网 站 上 可 以 下 载 PHPMyAdmin 软件 ,下 载 方法 是 : 在 浏览 器 网 址 栏 输入 
http://www. phpmyadmin. net/files/ ,打开 PHPMyAdmin 各 版 本 的 下 载 链接 网 页 ,选择 下 载 
版 本 3.5.2.2 的 压缩 包 文件 。 

2. PHPMyAdmin 的 安装 

首先 将 下 载 的 文件 解压 到 服务 器 的 主机 上 。 解 压缩 文件 夹 更 名 为 PHPMyAdmin 并 
移动 到 服务 器 的 网 页 文件 夹 内 ,如 D:\Server\Apache\HTDOCS。 

其 次 用 记事 本 打开 Libraries 目录 下 的 配置 文件 Config. Default. PHP。 按 Cul + 了 键 打 
开 查 找 对 话 框 ,搜索 以 下 配置 项 ,并 修改 对 应 值 : 

(1) 修改 访问 网 址 : 


Sfg["PmaAbsoluteUri'] ='"http://localhost/phpmyadmin' 

(2) 修改 MySQL 服务 器 端口 号 : 

$cfg['Servers'][ $i]["'port'] ="" 

使 用 MySQL 默认 端口 号 3306 ,保留 为 空 即 可 ,如 果 使 用 其 他 的 端口 号 , 则 需要 填写 。 

(3) 修改 MySQL 用 户 名 和 密码 : 

先 fg['Servers'][ 站] ['user'] ="'root" 

多 fg[ "Servers'] [站] ["password'] ='root 用 户 密码 ' 

填写 PHPMyAdmin 访问 MySQL 数据 库 时 的 用 户 名 和 密码 ,默认 为 root 用 户 。 

(4) 修改 认证 方法 : 

fg['Servers'][ 人 外] ['auth type'] ="'cookie' 

认证 方式 可 选择 4 种 模式 : Cookie .http .HTTP 和 Config。 其 中 Config 方式 无 须 输 入 
用 户 名 和 密码 可 直接 进入 ,不 推荐 使 用 。 其 他 方式 登录 PHPMyAdmin 时 都 需要 输入 数据 
库 用 户 名 和 密码 进行 验证 ,一 般 填 写 Cookie 作为 认证 方式 。 

(5) 设置 短语 密码 : 

和 fg["blowfish secret'] =' 短 语 密码 " 

如 果 需 要 通过 远程 服务 器 调用 PHPMyAdmin ,就 需要 设置 密码 ,此 处 不 能 空 ,否则 在 
登录 时 提示 错误 。 
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3. PHPMyAdmin 的 启动 


安装 PHPMyAdmin 后 ,可 以 通过 浏览 器 登录 MySQL 数据 库 管 理 系统 ,访问 数据 库 。 在 
浏览 器 中 打开 PHPMyAdmin 所 在 服务 器 页 面 , 如 http://localhost/phpmyadmin, 登 录用 户 
(如 root, 无 密码 ) , 便 可 以 看 到 MySQL 服务 器 中 的 数据 库 , 如 图 1-10 所 示 。 单 击 任意 数据 
库 查看 包含 的 数据 表 , 还 可 以 单 击 数 据 表 名 查看 数据 。 在 PHPMyAdmin 中 ,可 以 对 数据 
库 进行 各 种 操作 。 





























Serer 图 Iocalhost > Database- 号 web1_db1 
加 Suuctiie|| 及 SQL|| 部 Export|| 万 Search]| 兄 Quen]| 侨 
phpidyAdmin Table Action Records®@ Type 
Em 攻 面 Xx 1 MyISAM 
各 四 园 日 加 盏 轿 面 Xx 1 MyISAM 
Database: 已 i 略 牢 XX 0 MyISAM 
web1, db1 (27) 三 i 天 园 X 1 MyISAM 
(Databases) .… 四 
db_ispconfig (45) 必 轿 国 Xx 36 MylSAM 
mysql (15) | :了 面 XX 0 MyISAM 
= 四 9 加 同 区 0 MyISAM 
四 区 | E 阿 围 X 3 MyISAM 
目 lata 
i 一 轿 国 Xx 11 MyISAM 
m book_plcs | E 阿 围 X 1 MySAM 
book_private 
smilies 办 加 x ES 
图 1-10 PHPMyAdmin 界面 


1.7.3 Navicat 的 安装 与 测试 


1. Navicat 的 下 载 与 安装 


Navicat 包含 Navicat for MySQL、Navicat for SQL Server 和 Navicat for Oracle 等 多 个 成 
员 类 别 。 在 Navicat 的 官方 网 站 www. Navicat. com. cn 中 可 以 找到 Windows 环境 下 的 
Navicat for MySQL 软件 。 

双击 下 载 Windows 版 本 11.2 安装 应 用 程序 ,打开 软件 安装 的 欢迎 界面 ,在 安装 设置 
页 面 中 指定 安装 路 径 后 , 单 击 后 续 的 Next 按钮 即 可 完成 Navicat 的 安装 。 


2. Navicat 的 测试 


首次 使 用 Navicat for MySQL 应 用 程序 时 需要 配置 MySQL 服务 器 连接 。 单 击 软件 界 
面 中 的 连接 按钮 后 可 以 打开 “新 建 连接 "窗口 ,如 图 1-11 所 示 ,参数 设置 如 下 : 

(1) 连接 名 。Navicat 中 所 连接 MySQL 数据 库 的 使 用 名 。 

(2) 主机 名 或 耻 地 址 。 如 果 是 本 机 MySQL 数据 库 , 填 写 Localhost; 如 果 是 网 络 中 的 
远程 MySQL 数据 库 , 则 填写 所 在 主机 的 IP 地 址 。 

(3) 用 户 名 和 密码 。 所 连接 MySQL 数据 库 的 管理 用 户 和 密码 。 
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localserver 


localhost 
3306 Q 
root 

EPZ 


贺 保 存 宪 码 
图 1-11 Navicat 新 建 连接 窗口 


参数 设置 完成 后 , 单 击 测试 按钮 测试 服务 器 是 否 连接 。 如 果 正 确 连接 , 单 击 “ 确 定 ” 
按钮 完成 数据 库 配置 , 则 可 以 在 Navicat 中 查看 连接 数据 库 的 数据 。 




















1.8 XAMPP 软件 包 的 安装 与 测试 


1. 什么 是 XAMPP 


有 一 种 稳定 的 网 站 建设 方案 是 以 Linux 作为 操作 系统 , Apache 作为 Web 服务 器 ， 
MySQL 作为 数据 库 管 理 系 统 ,PHP 或 Perl 作为 服务 器 端 脚本 语言 。 由 于 这 个 组 合 都 是 免 
费 或 开放 源码 软件 (FLOSS ) ,因此 被 称 为 LAMP 组 合 。LAMP 凭借 其 特有 的 安全 ,快速 、 
易 用 .易于 开发 以 及 大 量 的 开源 代码 与 Windows IIS 和 . NET 等 商业 软件 进行 竞争 ,已 经 
成 为 一 种 Web 应 用 程序 部 署 的 事实 标准 。 

但 要 熟练 地 使 用 LAMP, 从 安装 配置 到 升级 维护 都 不 容易 ,为 了 简化 Web 部 署 流程 ， 
由 Apache Friends 开发 的 XAMPP(X 一 任意 系统 ,A 一 Apache, M 一 MySQL, P 一 PHP,P 
PHPMyAdmin/Perl) 为 建立 LAMP 站 点 提出 了 一 种 免费 、 跨 平台 的 解决 方案 。XAMPP 是 
一 个 集成 软件 包 , 提供 建站 所 需 软 件 的 一 站 式 安装 和 配置 ,支持 多 国语 言 , 可 以 在 
Windows .Linux 、Solaris .Mac 0S X 等 多 种 操作 系统 下 安装 使 用 。 由 于 XAMPP 的 易 用 性 ， 
使 它 成 为 大 量 低 成 本 网 站 首选 的 建站 软件 。 


2. XAMPP 的 下 载 与 安装 


作为 一 款 集成 软件 包 , XAMPP 包含 多 个 建设 网 站 常用 的 软件 ,只 要 在 官方 网 站 
http:/Awww. xampp. org/ 中 选取 一 个 安装 包 就 可 获取 多 款 网 站 所 需 软件 。 在 浏览 器 输入 
https://sourceforge. net/ projects/ xampp/files/ XAMPP% 20Windows/1. 8. 1/xampp-win32-1. 
8.1-VC9-installer. exe/download , 下载 本 书 使 用 的 1.8.1 版 本 ,包括 : Apache 2.4.3 、MySQL 
5.5.27 .PHP 5.4.7 和 phpMyAdmin3.5.2 等 组 件 。 

在 安装 XAMPP 之 前 ,如 果 系 统 中 已 经 安装 了 XAMPP 组 件 的 其 他 版 本 ,需要 先 印 载 ， 
再 开始 安装 。 运 行 XAMPP 安装 程序 进入 欢迎 界面 。 单 击 Next 按钮 ,打开 Setup 界面 , 选 
择 需要 安装 的 组 件 ,再 单 击 Next 按钮 ,设置 安装 路 径 , 如 D:\XAMPP 后 完成 安装 设置 。 
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3. XAMPP 的 测试 


XAMPP 安装 完成 后 ,自动 弹出 XAMPP 的 控制 台 窗口 ,如 图 1-12 所 示 。 在 窗口 中 可 
以 启动 和 配置 XAMPP 组 件 , 单 击 Apache 和 MySQL 的 Start 按钮 启动 Apache 和 MySQL 服 
务 , 此 时 下 面 的 控制 台 提 示 所 执行 的 操作 和 出 现 的 问题 。 如 果 正 常 启动 ,控制 台 不 出 现 错 
误 信息 ,并 将 Start 按钮 变 成 Stop 按钮 。 单 击 Stop 按钮 即 可 关闭 服务 。 
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图 1-12 XAMPP 的 控制 台 窗 口 


单 击 Apache 和 MySQL 前 面 的 Modules Service 按钮 ,可 以 将 Apache 和 MySQL 设置 为 
Windows 的 系统 服务 ,默认 为 开机 自动 启动 。 

开启 Apache 和 MySQL 服务 后 ,分 别 单 击 Apache 和 MySQL 组件 的 Admin 按钮 可 以 
打开 XAMPP 的 欢迎 页 面 和 登录 PHPMyAdmin 的 管理 页 面 。 


4. XAMPP 的 常用 配置 


初次 使 用 XAMPP 时 可 以 设置 配置 文件 ,以 满足 不 同 的 工作 环境 。 需 要 注意 的 是 配 
置 文件 修改 后 只 有 相关 服务 器 组 件 重新 启动 后 才能 生效 。 

(1) 修改 网 站 发 布 目录 。Apache 组 件 默认 的 网 站 发 布 目录 是 XAMPP 安装 目录 下 的 
HTDOCS 文件 夹 ,如 D:\xampp\htdocs。 单 击 Apache 组 件 的 Config 按钮 ,选择 httpd. conf， 
打开 Apache 的 配置 文件 。 以 htdocs 为 关键 字 搜 索 DocumentRoot 和 Directory 两 个 配置 
项 ,同时 修改 两 项 的 默认 值 就 可 以 设置 站 点 的 新 存放 目录 。 

例如 : 将 DocumentRoot "D:/ xampp/ htdocs" 和 < Directory " D:/xampp/ htdocs" > 

修改 成 DocumentRoot " D.:/rczp" 和 < Directory "D:/reczp" > 

(2) 设置 PHPMyAdmin 认证 方式 。 安 装 XAMPP 后 ,认证 方式 存放 在 配置 文件 中 , 启 
动 PHPMyAdmin 时 ,默认 以 root( 无 密码 ) 用 户 直接 登录 。 通 过 修改 配置 文件 中 的 认证 方 
式 , 可 以 选择 其 他 用 户 登 录 。 操 作 方 法 是 : 单 击 Apache 组 件 的 Config 按钮 ,选择 config. 
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inc. php。 找 到 $cfg['Servers' ][ $i]['auth_type’ ] =“config' 配 置 项 ,修改 config 为 
cookie ,存盘 后 再 启动 PHPMyAdmin ,可 以 输入 任何 用 户 名 和 密码 进行 登录 。 

(3) 设置 MySQL 使 用 UTF-8 编码 。MySQL 默认 使 用 latin-l 字符 集 ( 编码) , 当 涉 及 中 
文字 符 时 ,无 论 是 在 phpMyAdmin 中 管理 数据 库 , 还 是 在 网 页 中 显示 数据 都 可 能 出 现 乱 
码 ,因此 ,需要 设置 字符 集 为 UTF-8 编码 。 操 作 方 法 是 : 单 击 MySQL 组 件 的 Config 按钮 ， 
选择 my. ini ,打开 MySQL 的 配置 文件 ,删除 “## UTF 8 Settings" 行 下 面 5 行 左 边 的 注释 
“#” ,修改 后 的 内 容 如 下 : 

手 TF 8 Settings 

init -connect =\'SET NAMES utf8 \' 

collation server utf8 unicode ci 

Character set server utf8 

skip -character -set -client handshake 

Character sets -dir ="C:/xampp/mysql/share/charsets" 


(4) MySQL 组 件 默 认 将 数据 库 以 文件 夹 的 形式 保存 在 *…\xampp \mysql\data” 文 件 
夹 中 ,一 个 数据 库 对 应 一 个 文件 夹 。 


1.9 网 站 建设 的 流程 


建设 一 个 网 站 包含 很 多 步骤 ,只 有 完成 每 一 步骤 ,才能 建成 一 个 完整 的 网 站 。 虽 然 建 
站 没有 一 个 固定 的 规范 ,但 是 ,实际 实施 已 经 形成 一 个 基本 的 流程 ,通过 这 个 流程 按 部 就 
班 地 开发 网 站 ,能 够 提升 效率 和 减少 错误 。 


1. 规划 网 站 


网 站 在 设计 之 初 要 对 其 内 容 .目标 和 风格 进行 整体 规划 ,根据 市 场 . 环 境 和 目标 群体 
进行 分 析 , 明 确 网 站 的 定位 ,提供 什么 服务 或 传达 什么 信息 。 

例如 ,人 才 招 聘 网 站 的 主要 功能 是 为 公司 和 求职 者 搭建 一 个 沟通 的 平台 ,其 目标 群体 
为 公司 和 求职 人 员 ,能 提供 用 户 和 职位 信息 展示 ,考试 和 成 绩 管理 ,站 内 信息 搜索 等 功能 ， 
并 提供 个 人 博客 平台 。 


2. 确定 网 站 结构 


根据 网 站 的 功能 和 需求 ,为 网 站 的 目录 提供 配置 方案 ,明确 网 站 中 网 页 图片 动画、 
音 视频 和 数据 库 等 各 种 文件 的 存放 位 置 。 为 实现 人 才 招 聘 网 站 需要 创建 下 列 目录 ,其 中 
主 目 录 是 网 站 访问 的 根 目录 ,不 同 资源 应 该 在 主 目录 下 分 别 创建 资源 目录 。 

(1) 主 目录 。 新 建 网 站 的 主 目录 D:\rezp ,用 于 存放 网 站 的 主页 和 其 他 常用 页 面 。 

(2) 博客 目录 。 新 建 D:\rezp\blog 目录 ,用 于 存放 为 网 站 提供 个 人 博客 功能 的 网 页 。 

(3) 样式 文件 目录 。 新建 D:\rezp\ess 目录 ,用 于 存放 独立 于 网 页 的 CSS 文件 。 

(4) 图 片 文件 目录 。 新 建 D:\rezp \images 目录 ,用 于 存放 网 站 中 使 用 的 图 片 资源 。 
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3. 购买 网 站 空间 


网 页 文件 需要 保存 在 一 个 可 以 被 外 部 用 户 访问 的 网 站 空间 中 ,并 且 提 供 具有 良好 语 
义 的 域名 以 方便 用 户 访问 。 获 取 网 站 空间 一 般 有 3 种 方式 : 

(1) 购置 服务 器 。 购买 服务 器 主机 ,向 本 地 网 络 提供 商 申请 足够 的 网 络 带宽 和 固定 
IP 地 址 ,由 于 主机 性 能 要 求 高 且 需 要 专人 维护 ,适合 大 型 企业 。 

(2) 主机 托管 。 购 买 服务 器 主机 ,但 不 需要 固定 IP 地 址 ,而 是 将 整 机 交 由 运营 商 托 

管 ,由 运营 商 负责 网 络 管理 和 维护 ,适合 中 等 规模 网 站 。 

(3) 租用 虚拟 主机 。 虚拟 主机 是 指 在 一 台 服 务 器 主机 上 虚拟 出 多 个 可 以 独立 使 用 的 
网 站 空间 ,每 台 都 有 独立 的 IP 地 址 ,由 多 个 用 户 平 挫 硬 件 和 网 络 维护 成 本 ,是 中 小 型 网 站 
的 首选 方案 。 

人 才 招 聘 网 站 通过 租用 虚拟 主机 来 存储 网 页 文件 。 互 联网 上 有 许多 空间 服务 提供 
商 ,如 阿里 云 , 网 址 为 www. aliyun. com ,提供 了 多 种 类 型 的 虚拟 主机 ,如 图 1-13 所 示 。 选 
择 适 合 的 空间 大 小 .操作 系统 和 带宽 后 即 可 购买 其 使 用 权 。 


C3 阿里 云 万 网 虚 机 首页 。 x 





€ > GD https//wanwang.aliyuncom/hosting 
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图 1-13 阿里 云 主机 介绍 页 面 











4. 申请 域名 


互联 网 中 的 每 台 主 机 都 对 应 不 同 的 IP 地 址 ,用 于 互相 访问 定位 。 因 为 IP 地 址 全 由 
数字 组 成 难于 记忆 ,网 站 都 会 申请 域名 ,让 用 户 通过 域名 访问 网 站 。 空 间 服务 提供 商 一 般 
都 会 提供 域名 注册 服务 ,首先 查询 所 需 域名 ,如 rezp. com, 是 否 被 注册 , 若 可 用 , 则 购买 该 
域名 的 使 用 权 并 与 网 站 空间 的 IP 地 址 进行 绑 定 。 
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5. 发 布 网 站 


一 般 虚拟 主机 会 提供 一 个 专用 于 文件 传输 的 FTP(File Transfer Protocol ,文件 传输 协 
议 ) 地 址 ,可 以 使 用 各 种 FTP 客户 端 ,如 Dreamweaver 中 的 FTP 工具 ,将 网 站 的 所 有 文件 上 
传 到 空间 服务 器 上 。 此 后 用 户 就 可 以 通过 浏览 器 输入 域名 浏览 网 站 内 容 。 

综 上 所 述 ,网 站 的 建设 是 一 个 系统 性 工程 ,涉及 诸多 软件 和 技术 的 协同 工作 ,但 最 重 
要 的 还 是 网 站 内 容 的 建设 。 现 代 的 网 站 以 动态 网 页 为 主 ,需要 数据 库 技术 支持 。 实 际 上 
网 站 内 容 设计 的 首要 工作 是 一 一 数据 库 设 计 。 


习 题 


一 、 填空 题 


1. 随 着 互联 网 的 发 展 ,计算 机 软件 可 以 分 成 两 个 类 别 : 采用 QD 软件 体系 结构 的 
_@ 程序 ,将 程序 和 数据 安装 在 一 台 主 机 中 ,采用 _@) 体系 结构 的 _@ 程序 将 程序 
和 数据 分 配 到 不 同 主机 。 

2. 在 某 网 络 游戏 中 ,需要 下 载 网 游客 户 端 到 用 户 机 器 上 安装 ,才能 与 他 人 共同 游戏 ， 
这 属于 网 络 应 用 程序 中 的 _ 中 “模式 ,可 以 缩写 为 ”加 “。 如 果 无 须 下载 安 装 客户 端 程 
序 ,打开 网 页 就 能 直接 进行 游戏 ,采用 的 网 络 应 用 模式 是 _@) 模式 ,可 以 缩写 为 四 。 

3. 动态 网 页 能 根据 用 户 的 不 同 请 求生 成 不 同 内 容 的 页 面 , 例 如 登录 一 个 人 才 招 聘 网 
站 时 用 户 从 客户 端 浏览 器 中 看 到 的 是 _ 四 “网 页 ,通过 页 面 中 的 按钮 向 服务 器 发 送 求 职 
请 求 ,服务 器 接收 到 请 求 后 ,运行 _@ 编写 的 程序 ,并 查找 _ 国 ”获取 求职 信息 生成 新 
的 页 面 , 回 传 给 浏览 器 。 

4. 用 浏览 器 访问 网 站 实际 上 就 是 QD 和”@@ 交互 的 过 程 ,两 者 一 般 通 过 _@_ 
规定 的 流程 和 标准 通信 格式 进行 通信 。 

5. 建设 一 个 LAMP 站 点 通常 是 用 _Q@_ 作 为 操作 系统 ， @ ”作为 网 页 服务 器 ， 
_ @@_ 作 为 数据 库 ， @_ 作 为 服务 器 端 脚 本 。 这 些 软 件 都 是 免费 上 且 开 放 源 代码 的 。 

6. 客户 端 程序 设计 主要 就 是 指 通过 中 、@ 和 @ 语言 的 综合 使 用 构造 静 
态 网 页 ,并 使 网 页 产生 动态 的 显示 效果 。 

7. 在 建设 低 成 本 网 站 时 常 使 用 Apache 服务 器 和 MySQL 数据 库 ,并 根据 当前 环境 配 
站 相关 参数 , Apache 软件 的 配置 文件 是 _@ ,MySQL 的 配置 文件 是 _@ 。 

8. 在 PHPMyAdmin 程序 安装 过 程 中 ,主要 是 对 程序 进行 配置 。 在 配置 文件 中 , $ cfg 
['PmaAbsoluteUri' ] 的 作用 是 “四 ,$cfg['Servers' ] [$i]['port'] 的 作用 是 @ ， 
$cfg['Servers’ ] [ $ 让 [auth_type' ] 的 作用 是 _@@ 。 

9. 在 制作 网 页 时 ,标准 的 静态 网 页 是 采用 QD 语言 编写 的 ,为 了 使 网 页 的 编写 和 
维护 更 方便 ,还 使 用 _@ 专门 实现 样式 设计 。 

10. 在 XAMPP 的 控制 台面 板 中 可 以 对 组 件 进行 手动 设置 ,其 中 QD 按钮 用 于 开启 
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服务 ， @， 按钮 打开 配置 文件 ， @ 按钮 打开 管理 页 面 。 


二 、 单 选 题 
1. 浏览 器 发 送 请 求 消息 和 接收 响应 消息 遵守 ( ) 网 络 协议 。 
A. FTP B. HTTP C. TCP/IP D. DNS 


2. 关于 MySQL 数据 库 的 说 法 ,错误 的 是 (。”)。 
A. MySQL 支持 跨 平台 使 用 ,例如 可 以 在 Linux 系统 中 使 用 
B. MySQL 数据 库 启动 后 可 以 在 任务 管理 器 中 查看 到 MySQL 进程 
C. 手动 更 改 MySQL 数据 库 的 my. ini 文件 ,不 能 更 改 端口 号 
D. 登录 MySQL 数据 库 后 输入 help ,可 以 查看 命令 帮助 信息 
3. 只 能 运行 于 Windows 系统 的 网 页 服务 器 是 ( Ne 


A. MySQL B. Tomcat C. Apache D: I 
4. 完全 免费 且 开 放 源 代码 的 数据 库 软 件 是 ( )。 
A. SQL Server B. MySQL C. DB2 D. Oracle 


5. 初次 安装 XAMPP 后 ,内 部 组 件 都 会 使 用 默认 的 设置 工作 ,下 列 关 于 XAMPP 及 其 
组 件 配置 的 描述 ,错误 的 是 ( js 
A. XAMPP 默认 的 网 页 发 布 目 录 是 HTDOCS 文件 夹 
B. MySQL 中 的 数据 库 默 认 保存 目录 是 data 文件 夹 
C. PHPMyAdmin 默认 通过 用 户 名 和 密码 登录 
D. MySQL 的 配置 文件 中 默认 使 用 # 代 表 注 释 
6. 下 列 计算 机 语言 中 ,( ) 不 是 常用 的 服务 器 端 脚本 语言 。 


A. JSP B. ASP CG. PHP D. JavaScript 
7. 下 列 计算 机 语言 中 ,( ) 不 是 常用 的 客户 端 网 页 设计 语言 。 
A. HTML B. VBScript ,9 D. Java 


8. 在 下 列 数据 库 软 件 中 ,( ) 不 能 在 Linux 操作 系统 和 Windows 操作 系统 中 都 正 


常 运行 。 


A. SQL Server B. MySQL C. DB2 D. Access 
9. 在 下 列 选项 中 ,( ) 不 是 常见 的 数据 库 管理 工具 。 
A. Navicat B. PHPMyAdmin C. Workbench D. Access 


10. 建设 并 真正 运营 一 个 人 才 招 聘 网 站 需要 完成 许多 基本 步骤 ,( ) 不 是 网 站 建 
设 必须 经 历 的 过 程 。 

A. 获取 空间 B. 申请 域名 C. 绑 定 域名 D. 配置 Apache 
11. 在 下 面 关 于 网 页 的 叙述 中 ,错误 的 是 (  )。 

A. 网 页 是 包含 文字 .图 片 动画 等 媒体 信息 的 页 面 文档 

B. 动态 网 页 是 指 网 页 的 内 容 可 根据 用 户 需 要 动态 修改 

C. 静态 网 页 是 指 网 页 在 浏览 器 中 的 页 面 静止 不 动 

D. 网 页 通过 超 链接 跳 转 到 其 他 页 面 
12. MySQL 服务 器 的 默认 端口 号 是 ( )s 
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A. 80 B. 8080 C. 3306 D; 127 


三 、 多 选 题 

1. 以 下 软件 中 ( ) 不 是 专用 的 可 视 化 网 页 编辑 软件 。 
A. FrontPage B. Dreamweaver C. PHPMyAdmin D. 记事 本 
E. Photoshop F. Apache 

2. 在 Windows 操作 系统 中 可 以 安装 ( ) 数 据 库 服务 器 。 
A. Apache B. Tomcat C. MySQL D. Oracle 
E. SQL Server F. PostgreSQL 

3. 下 列 软 件 中 ,( ”) 是 专用 于 MySQL 数据 库 的 工具 。 
A. Navicat B. PHPMyAdmin 
C. MySQL GUI Tools D. SQLyog 
E. Navicat for MySQL F. Workbench 

4. XAMPP 是 低 成 本 网 站 建设 的 常用 软件 包 , 主 要 包含 ( ) 软件。 
A. Linux B. Apache C. Perl D. MySQL 
E. PHP F. Dreamweaver 


5. 下 列 关于 Apache 服务 器 叙述 中 ,错误 的 是 ( No 
A. Apache 服务 器 软件 现在 可 以 在 官方 网 站 上 免费 下 载 
B. Apache 服务 器 曾经 是 世界 上 使 用 率 最 高 的 服务 器 
C，Apache 服务 器 无 须 设置 就 可 以 运行 PHP 文件 
D. Apache 服务 器 支持 跨 平 台 
E. Apache 服务 器 软件 默认 网 页 目录 是 data 
6. MySQL GUI Tools 是 一 个 由 MySQL 官方 提供 的 MySQL 数据 库 管理 控制 台 ,包括 多 
个 工具 程序 ,( ) 不 是 其 中 所 包含 工具 。 


A. MySQL Migration Toolkit B. MySQL Administrator 
C. MySQL PHPMyAdmin D. MySQL Manager 
E. MySQL Workbench F. MySQL Query Browser 
7. 下 列 软件 中 ,( ” “”) 不 是 一 个 LAMP 站 点 所 必需 的 软件 。 
A. MySQL B. PHP C. PHPMyadmin D. Ajax 
E. Apache 


8. 在 下 列 关 于 XAMPP 的 叙述 中 ,错误 的 是 ( )。 
A. XAMPP 包含 建立 ASP 站 点 的 软件 
. XAMPP 不 能 安装 在 Linux 服务 器 上 
. XAMPP 支持 免费 下 载 
. XAMPP 支持 Perl 脚本 语言 
. XAMPP 适合 大 多 数 大 型 的 网 站 
F. XAMPP 是 LAMP 组 合 的 一 个 压缩 文件 
9. 正式 运行 网 站 ,需要 将 网 站 内 容 放置 到 一 个 拥有 固定 IP 地 址 的 主机 空间 中 ,下 列 
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二 一 


选项 中 ( 。 ”) 是 获取 网 站 空间 常见 的 方式 。 


A. 自己 购买 主机 并 申请 固定 人 P B. 自己 购买 主机 并 委托 给 运营 商 
C. 自己 购买 主机 和 他 人 共享 P D. 使 用 自己 的 个 人 主机 运营 网 站 
E. 租用 空间 提供 商 的 虚拟 空间 F. 租用 空间 提供 商 的 服务 器 


1. 日 常 所 用 的 计算 机 程序 中 ,哪些 属于 B/S 结构 ? 哪些 属于 C/S 结构 ? 哪些 是 纯 桌 
面 型 应 用 程序 ? 

2. 什么 是 HTTP 协议 ?HTTP 协议 是 如 何 工 作 的 ? 

3. 什么 是 客户 机 ? 什么 是 服务 器 ? 浏览 器 和 服务 器 分 别 工作 在 哪里 ? 

4. 什么 是 静态 网 页 ? 什么 是 动态 网 页 ? 在 日 常生 活 中 所 访问 的 网 页 如 何 区 分 属于 
哪 种 类 型 ? 

5. 如 何 设 置 可 以 使 XAMPP 中 的 服务 在 开机 时 自动 启动 ? 如 何在 Window 命令 窗口 
中 通过 命令 启动 XAMPP 中 的 服务 ? 
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数据 库 逻 辑 设计 及 数据 库 系 统 结构 


在 计算 机 中 进行 各 种 业务 处 理 ,主要 是 针对 客观 事物 的 特征 和 业务 流程 进行 处 理 , 因 
此 ,在 对 各 种 业务 进行 计算 机 处 理 之 前 ,需要 对 客观 事物 的 特征 进行 规范 化 ,抽象 化 和 数 
字 化 处 理 , 以 便 将 客观 事物 的 特征 以 数据 的 形式 存储 于 计算 机 中 。 对 各 种 业务 流程 进行 
智能 化 和 自动 化 模拟 处 理 ,依靠 运行 计算 机 程序 进行 驱动 。 

数据 库 ( DataBase ,DB) 是 有 组 织 结构 化 的 相关 联 数据 的 集合 ,是 存储 事物 特征 最 有 
效 的 一 种 软件 工具 ,主要 内 容 是 数据 表 、 主 键 和 表 之 间 的 关联 等 信息 。 特 别 是 大 数据 时 
代 , 计 算 机 网 络 中 的 绝 大 部 分 数据 都 存储 于 数据 库 中 。 

设计 数据 库 主要 包括 针对 具体 业务 的 需求 分 析 概念 设计 、 则 辑 设计 和 物理 设计 (在 
数据 库 管理 系统 中 建立 数据 库 )4 个 环节 。 数 据 库 旭 辑 设计 的 主要 任务 是 研究 如 何 将 客 
观 事物 及 其 特征 抽象 成 数据 库 中 的 数据 , 即 研究 把 客观 事物 的 特征 转换 为 数据 库 中 数据 
的 规范 化 过 程 、 理 论 依据 和 技术 方法 ,并 不 是 在 计算 机 上 实际 设计 数据 库 ( 物 理 设计 ) 。 
主要 回答 如 下 问题 : 

(1) 针对 某 种 具体 业务 需求 ,如 何 为 设计 数据 库 做 准备 工作 ? 

(2) 如 何 抽象 与 规范 相关 业务 流程 和 事物 ,使 相关 信息 能 存储 到 数据 库 中 ? 

(3) 数据 库 的 常见 术语 有 哪些 ?主键 和 外 键 对 数据 库 有 什么 作用 ? 

(4) 如 何 将 表格 规范 化 成 数据 表 ? 为 什么 要 对 数据 表 进 行规 范 化 ? 规范 化 的 理论 依 
据 \ 原 则 和 技术 方法 是 什么 ? 非 规范 化 的 数据 表 对 实际 应 用 会 产生 哪些 影响 ? 

(5) 数据 编码 的 意义 和 作用 是 什么 ?通常 哪 类 数据 适合 于 编码 ?数据 编码 对 关系 模 
式 有 哪些 影响 ”对 信息 数字 化 进程 有 哪些 影响 ? 

(6) 数据 库 系 统 是 如 何 构成 的 ,各 层 之 间 是 如 何 协调 运行 的 ? 

从 实际 业务 需求 及 应 用 出 发 ,竭力 理 清 这 些 问题 ,引导 读者 学 会 设计 实用 数据 库 是 本 
草 的 主旨 。 


2.1 数据 库 逻 辑 设计 的 前 期 准备 工作 





一 个 数据 库 中 往往 存储 着 与 某 种 业务 密切 相关 的 事物 对 象 、 对 象 之 间 的 关联 及 其 特 
征 。 因 此 ,在 轨 辑 设计 数据 库 之 前 ,要 对 具体 业务 进行 需求 分 析 和 概念 设计 ,以 便 根 据 具 


体 业 务 流程 和 任务 要 求 合理 有 效 地 组 织 和 设计 数据 库 。 


2.1.1 需求 分 析 


需求 分 析 主 要 对 要 建立 数据 库 的 业务 流程 和 任务 要 求 进行 分 析 。 在 此 阶段 ,数据 库 
设计 人 员 应 该 与 业务 人 员 反 复 交流 ,熟悉 业务 范围 流程 处 理 细节 法 律 法 规 和 数据 库存 
储 环境 等 ,以 便 全 面 而 细致 地 规范 和 分 析 业 务 流程 ,收集 、 归 纳 、 分 析 和 总 结业 务 资料 ,最 


1. 分 析 业 务 流程 


业务 流程 分 析 主 要 对 人 们 处 理 实际 业务 的 过 程 进行 归纳 和 总 结 ,以 便 数据 库 设 计 人 
员 全 面 掌握 业务 处 理 的 总 体 流 程 和 思想 。 通 常 以 流程 图 的 方式 进行 描述 ,例如 ,描述 网 上 
人 才 招 聘 业 务 流程 如 图 2-1 所 示 。 
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图 2-1 网 上 人 才 招 聘 业 务 流程 图 


在 业务 流程 分 析 过 程 中 ,要 反复 与 业务 人 员 交 流 洽谈 ,不 断 了 解 和 规范 业务 流程 ,对 
业务 中 各 个 环节 了 解 和 总 结 得 越 细致 越 透 彻 , 设 计 和 规划 数据 库 时 就 越 容易 . 越 高 效 。 


2. 搜集 和 整理 相关 业务 资料 

根据 业务 流程 ,搜集 和 整理 各 个 环节 的 相关 资料 ,如 法 律 法 规 、 业 务 规范 以 及 各 种 表 
格 。 例 如 ,网 上 人 才 招聘 业务 的 相关 表格 如 表 2-1 和 表 2-2 所 示 。 
2.1.2 概念 设计 


念 设 计 主 要 分 离 出 相关 业务 中 的 客观 事物 (如 岗位 和 应 聘 人 员 ) ,提取 各 种 事物 的 
特征 (如 岗位 编号 .岗位 名 称 \ 人 数 和 姓名 等 ) ,分 析出 各 类 事物 之 间 的 关联 (如 聘任 和 应 
聘 ) ,用 概念 模型 描述 事物 及 其 关联 ,分 析 每 个 数据 项 的 数据 语义 。 


1. 概念 模型 

概念 模型 是 描述 现实 世界 的 事物 及 其 关联 的 数据 模型 ,与 具体 的 数据 库 管 理 系统 
(DBMS) 无 关 。 将 事物 抽象 成 概念 模型 ,通过 概念 模型 的 逼真 性 .直观 性 .通俗 性 和 通用 
性 ,使 事物 及 其 关联 更 加 清晰 易 懂 , 便 于 数据 库 设计 人 员 与 业务 人 员 交 流 和 沟通 ,设计 出 
更 实用 的 数据 库 。 
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最 典型 的 概念 模型 是 E-R( Entity-Relationship , 实体 关系 ) 模 型 。 例 如 ,人 才 招 聘 业务 
的 E-R 模型 如 图 2-2 所 示 。 













人 





应 聘 人 员 








图 2-2 ”人才 招 聘 业 务 的 E-R 模型 


在 E-R 模型 中 ,用 矩形 框 注 明文 字 表示 实体 (事物 ,例如 岗位 .应 聘 人 员 ) ;用 椭圆 形 
框 注 明 文字 表示 属性 (特征 ,例如 岗位 名 称 、 人 数 、 所 学 专业 等 ) , 连 线 表示 隶属 关系 ;用 区 
形 框 表示 实体 之 间 的 关联 , 框 内 文字 注 明 关联 方式 (例如 聘用 ) 。 
2. 分 析 数 据 语 义 
数据 语义 是 指 和 人 们 对 数据 含义 的 规定 与 解释 。 在 数据 库 规范 化 过 程 中 ,不 能 仅 从 数 
据 表面 分 析 其 语义 ,要 依据 数据 的 内 涵 现实 意义 和 作用 分 析 与 理解 数据 语义 。 例 如 , 根 
据 搜 集 和 整理 的 相关 资料 以 及 业务 规范 ,网 上 人 才 招 聘 业 务 中 用 人 岗位 表 和 应 聘 人 员 基 
本 情况 表 的 相关 数据 项 的 语义 如 表 2-3 和 表 2-4 所 示 。 
表 2-3 用 人 岗位 表 中 数据 项 的 语义 
数据 项 名 语义 
岗位 编号 招聘 岗位 的 唯一 标识 ,可 以 是 大 小 写 英文 字母 或 数字 ,最 多 5 个 字符 
岗位 名 称 可 以 是 汉字 或 英文 ,最 多 30 个 字符 (15 个 汉字 ) 
最 低 学 历 岗位 对 学 历 的 要 求 , 分 大 专 .本 科 ,研究 生 或 博士 ,最 多 3 个 汉字 或 1 位 编码 
最 低 学 位 岗位 对 学 位 的 要 求 , 分 无 学 位 (或 空 ) ,学士 .硕士 或 博士 ,最 多 3 个 汉字 或 1 位 编码 


























人 数 范围 为 1~999 的 整数 
年 龄 上 限 是 招聘 人 员 的 最 大 年 龄 ,范围 为 18 ~60 的 整数 
年 薪 范围 为 1 ~ 10 000 000 的 整数 





笔试 成 绩 比 例 | 是 笔试 成 绩 占 总 成 绩 的 百分比 ( % ) ,0 表示 不 要 求 笔试 
笔试 日 期 笔试 考试 日 期 


聘任 要 求 对 聘任 人 员 的 其 他 要 求 , 如 相关 技能 、 外 语 语种 性别、 婚姻、 所 学 专业 、 特 长 ,笔试 科 
目 内 容 要 求 等 ,最 多 可 以 100 个 汉字 


公司 名 称 单位 名 称 , 汉 字 、 英 文 均 可 ,最 多 40 个 字符 (20 个 汉字 ) 
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( 续 表 ) 



































数据 项 各 语义 
公司 地 址 。 ”| 预计 工作 所 在 的 城市 或 区 域 ,最 多 15 个 汉字 
邮政 编码 。。 | 6 位 数字 国家 标准 代码 
表 2-4 应 聘 人 员 基 本 情况 表 中 数据 项 的 语义 
数据 项 各 语义 
身份 证 号 应 聘 人 员 的 唯一 标识 ,可 由 身份 证 号 中 获取 户籍 所 在 地 、 出 生日 期 和 性 别 等 信息 ， 
18 个 字符 ,由 英文 字母 和 数字 组 成 
姓名 应 聘 人 员 姓 名 ,最 多 5 个 汉字 
婚 否 婚姻 状态 ,分 已 婚 未婚 
最 后 学 历 ee, ` 大 专 本 科研 究 生 或 博士 ,最 多 3 个 汉字 
的 丙 学 位, 共 天 学科 (下 宇 ] -学 工 \ 硕 荆 或 博士 ;最多 3 不 汉字 或 T 位 
所 学 专业 所 学 专业 名 称 ,最 多 15 个 汉字 





地 址 及 邮政 编码 | 地 址 为 通信 地 址 ,最 多 25 个 汉字 ; 另 加 6 位 邮政 编码 



































Email 账号 电子 邮箱 地 址 ,最 多 30 个 字符 

QQ 账号 最 多 30 个 字符 

固定 电话 包含 区 号 的 办 公 或 住宅 电话 号 ,最 多 20 个 字符 

移动 电话 最 多 15 位 数码 

个 人 简历 应 聘 人 员 的 主要 学 习 和 工作 经 历 , 可 长 达 64KB 

岗位 编号 与 用 人 岗位 表 中 设置 的 岗位 一 致 ,每 个 应 聘 人 员 可 以 申报 多 个 岗位 

资格 审核 资格 审核 是 否 通过 ,分 通过 和 未 通过 

笔试 成 绩 百分制 笔试 成 绩 , 取 整数 

面试 成 绩 百分制 面试 成 绩 , 取 整数 

总 分 总 分 = 笔试 成 绩 x 笔试 成 绩 比 例 /100 + 面试 成 绩 x (100 -笔试 成 绩 比例 )/100 


在 设计 数据 库 时 ,根据 数据 的 语义 确定 表 的 关键 字数 据 项 性 质 ( 数 据 类 型 ) 和 数据 
范围 (数据 项 宽度 ) 。 例 如 ,依据 表 2-3 中 的 语义 分 析 ,“ 岗位 编号 "是 用 人 岗位 表 ” 中 的 
关键 字 , 数 据 项 性 质 为 字符 型 ,宽度 为 5 位 。 按 照 表 24 中 的 语义 分 析 ,“ 身 份 证 号 ”为 字 


符 型 18 位 。 男 


外 ,由 于 一 个 应 聘 人 员 可 以 同时 申报 多 个 岗位 ,所 以 “身份 证 号 "不 能 单独 


作为 “应 聘 人 员 基 本 情况 表 ” 的 关键 字 , 它 必须 与 “岗位 编号 "共同 组 成 关键 字 。 

总 之 ,在 进行 数据 库 逻 辑 设计 之 前 ,对 计算 机 要 处 理 的 具体 业务 进行 需求 分 析 和 概念 
设计 ,为 优化 数据 表 , 降 低 数据 元 余 ( 重复 存储 ) ,减少 数据 操作 (更 新 .插入 和 删除 ) 异常， 
建立 事物 之 间 的 关联 等 积累 扎实 的 资料 ,为 进一步 的 数据 库 逻 辑 设计 做 好 充分 的 准备 
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2.2 数据 表 及 其 常见 术语 


数据 库 管理 系统 (DBMS ) 是 用 于 建立 维护 和 管理 数据 库 的 系统 软件 。 根 据 DBMS 
所 支持 的 数据 模型 不 同 ,可 分 为 层次 模型 ,网 状 模型 .面向 对 象 模型 和 关系 模型 的 DBMS ， 
其 中 关系 模型 是 目前 应 用 最 广泛 的 数据 模型 。 在 DBMS 的 控制 下 ,可 以 创建 .维护 和 使 用 
数据 库 ,虽然 不 同 的 DBMS 管理 数据 库 的 机 制 有 些 差异 ,但 是 ,关系 数据 库 中 都 是 以 数据 
表 ( 简称 表 ) 的 形式 存储 数据 ,在 设计 和 应 用 关系 数据 库 的 过 程 中 ,经 常 要 用 到 下 列 一 些 


概念 。 
1. 实体 


实体 是 客观 事物 的 真实 反映 ,可 以 是 实际 存在 的 对 象 , 也 可 能 是 某 种 抽象 的 概念 或 
事件 。 例 如 ,一 个 学 生 一 本 教材 和 一 台 计 算 机 等 都 是 实体 ,一 个 岗位 一 门 课程 一 个 专 
业 和 一 次 借阅 图 书 等 也 都 是 实体 。 


2. 实体 型 


实体 型 是 实体 类 型 的 简称 ,用 于 表示 一 类 实体 ,通过 实体 型 可 以 区 分 不 同类 型 的 事 
物 。 例 如 ,“ 应 聘 人 员 " 是 实体 型 ,“ 刘 德 厚 ”" 和 * 王 丽 敏 "分 别 是 应 聘 人 员 中 的 两 个 实体 ; 
“岗位 ”是 另 一 个 实体 型 ,“ 行 长 助理 "和 “银行 柜员 "等 都 是 其 中 的 实体 。 


3. 关系 


关系 是 无 重复 数据 行 的 二 维 表 , 也 称 数据 表 或 简称 表 。 从 定义 中 可 以 看 出 ,数据 表 中 
不 允许 套 表 ,每 个 单元 格 中 只 允许 存储 一 个 值 。 例 如 , 表 2-1 可 以 直接 转换 成 数据 表 。 

但 是 ,并 不 是 每 张 表格 都 可 以 直接 作为 数据 表 。 例 如 ,从 表 22 的 纵向 列 的 构成 分 
析 来 看 , 它 由 应 聘 人 员 的 “基本 信息 ”和 “考核 成 绩 " 两 个 子 表 构 成 ;从 横向 数据 行 的 分 
析 来 看 ,一 个 应 聘 人 员 的 “基本 信息 " 占 一 行 , 由 于 可 申报 多 个 岗位 ,而 其 “考核 成 绩 " 可 
能 占 多 行 ,因此 , 表 22 不 是 二 维 表 。 要 使 其 成 为 数据 表 , 必须 改造 成 二 维 表 , 如 表 2-5 
所 示 。 

从 表 2-5 可 以 看 出 ,在 改造 后 的 二 维 表 中 ,申报 多 个 岗位 的 应 聘 人 员 的 基本 信息 (如 
身份 证 号 .姓名 和 最 后 学 历 等 ) 需 要 多 次 重复 存储 ! 

一 个 数据 库 主要 由 若干 个 关联 的 表 构 成 。 一 个 表 由 实体 型 的 属性 信息 (名 称 、 类 型 
和 宽度 等 ,也 称 表 结 构 ) 和 属性 值 ( 数 据 行 ) 两 部 分 构成 。 一 个 表 存 储 一 个 实体 型 或 实体 
型 之 间 的 关联 ,一 行 数据 存储 一 个 实体 或 实体 之 间 的 关联 。 


4. 属性 


表 中 的 每 一 列 都 是 属性 ,也 称 为 列 .字段 或 数据 项 。 每 个 属性 都 有 属性 名 , 常 称 为 列 
名 或 字段 名 。 
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一 个 表 中 至 少 包含 一 个 属性 ,但 不 允许 包含 重 名 属性 。 通 常 划分 属性 的 基本 原则 是 
由 一 个 数据 语义 定义 一 个 属性 , 即 属性 具有 原子 性 。 在 表 2-5 中 ,各 列 的 标题 ( 如 身份 证 
号 姓名 和 婚 否 等 ) 均 为 属性 名 。 属 性 及 其 相关 信息 ( 名称、 类 型 和 宽度 等 ) 作 为 表 结 构 中 
的 主要 内 容 存储 于 表 中 。 


5. 记录 


表 中 各 个 属性 的 每 组 值 都 构成 了 一 行 数据 ,数据 行 也 称 为 元 组 ,数据 记录 (或 简称 记 
录 ) 。 一 个 记录 表示 一 个 实体 或 实体 间 的 关联 , 表 中 数据 就 是 由 这 样 的 诸多 记录 构成 的 。 
但 是 ,一 个 表 中 不 允许 重复 存储 记录 , 即 任何 两 个 记录 中 ,至 少 有 一 个 属性 的 值 不 同 。 通 
常 将 只 有 表 结 构 而 没有 存储 记录 的 表 称 为 空 表 。 

例如 , 表 2-5 中 的 (229901199503121538 , 刘 德 厚 , 否 , 本 科 ,…,A0002 ,通过 ,80,85， 
82) 和 (119801199210011321 , 王 丽 敏 , 否 ,研究 生 ,…,A0001 ,通过 ,75,90,80) 均 是 数据 
记录 。 


6. 关键 字 


关键 字 是 表 中 能 唯一 标识 记录 的 最 少 的 属性 集合 ,通常 也 将 关键 字 称 为 键 候选 键 或 
候选 码 。 

关键 字 主 要 用 于 检查 和 控制 表 中 记录 的 唯一 性 (任意 两 个 记录 关于 关键 字 的 值 都 不 
相同 ) ,实现 表 之 间 的 关联 等 ,因此 ,每 个 表 都 至 少 有 一 个 关键 字 。 

多 数 表 用 一 个 属性 就 可 以 确定 关键 字 , 例 如 , 表 2-1 中 的 岗位 编号 属性 。 某 些 表 需要 
多 个 属性 才能 构建 关键 字 , 例 如 , 表 2-5 中 需要 ( 身份 证 号 ,岗位 编号 ) 两 个 属性 共同 组 成 
关键 字 。 而 在 个 别 表 中 ,通过 已 有 的 属性 很 难 确定 关键 字 , 通 常 要 增设 记录 自动 编号 ( 记 
录 系 列 号 ) 属性 ,确保 表 有 关键 字 。 


7. 主 属性 


一 个 表 由 多 个 属性 构成 ,通常 将 包含 在 关键 字 中 的 属性 称 为 主 属性 ,将 不 在 任何 关键 
字 中 的 属性 称 为 非 主 属性 。 例 如 ,身份 证 号 ”和 ”岗位 编号 ”分别 是 表 2-5 的 两 个 主 属 
性 ,而 “姓名 "和 ”笔试 成 绩 "等 均 是 非 主 属性 。 

为 了 确保 关键 字 的 值 能 唯一 地 确定 数据 记录 ,输入 或 修改 数据 记录 时 DBMS 要 求 表 
的 主 属性 值 不 能 空 ( Null) , 即 主 属性 都 要 有 确定 的 值 。 


8. 主 关键 字 


虽然 一 个 表 中 可 能 有 多 个 关键 字 , 但 在 某 一 阶段 只 用 一 个 关键 字 控 制 表 中 数据 记录 
的 顺序 。 通 常 将 目前 选用 的 关键 字 称 为 主 关键 字 ,也 简称 为 主键 . 主 码 。 主 关键 字 是 关键 
字 之 一 ,每 个 表 可 以 有 多 个 关键 字 , 但 只 能 有 一 个 主 关键 字 。 主 关键 字 除 控制 记录 唯一 性 
外 ,还 用 于 控制 表 中 数据 记录 的 顺序 ( 按 主 关键 字 的 值 升序 或 降序 排列 ) 以 及 与 其 他 表 建 
立 关联 。 

例如 ,岗位 编号 可 选 为 表 2-1 的 主 关 键 字 ,( 身份 证 号 ,岗位 编号 ) 可 以 选 为 表 2-5 的 
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9. 外 键 


对 于 表 R 中 的 一 组 属性 F, 如 果 下 不 是 R 的 关键 字 ,而 恰 与 另 一 个 表 $ 的 主键 相对 应 
(数据 语义 相同 ) , 则 了 是 表 R 的 外 码 或 者 外 键 。 

外 键 通常 用 于 表 R 与 表 S 建立 关联 。 例 如 ,在 表 2-5 中 ,岗位 编号 "不 是 关键 字 ( 只 
是 主 属性 ) ,而 与 表 2-1 中 的 “岗位 编号 "数据 语义 相同 ,因此 ,“ 岗 位 编号 "是 表 2-5 的 外 
键 。 在 表 2-5 与 表 2-1 建立 关联 时 ,“ 岗 位 编号 "将 作为 关联 的 关键 字 。 


10. 关系 模式 


关系 模式 是 对 关系 ( 表 ) 的 描述 ,是 关系 名 ( 表 名 ) 及 其 所 有 属性 的 集合 ,表示 格式 为 : 
关系 名 ( 全 部 属性 名 表 ) 。 
【 例 2.1】 用 关系 模式 分 别 描述 用 人 岗位 表 和 应 聘 人 员 基 本 情况 表 。 


用 人 岗位 表 (岗位 编号 ,岗位 名 称 , 最 低 学 历 , 最 低 学 位 ,人 数 ,年 龄 上 限 , 年 薪 , 笔 试 成 绩 比例 ,笔试 
日 期 ,聘任 要 求 , 公 司 名 称 , 公 司 地 址 ,邮政 编码 ) 





应 聘 人 员 基 本 情况 表 (身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 ,最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 编码 ， 

Email 账号 ,0Q 账号 ,固定 电话 ,移动 电话 ,个 人 简历 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,总 

分 ) 

关系 模式 实际 是 表 结构 的 形式 化 表示 ,用 下 夯 线 标记 主 属性 。 关 系 模式 可 以 抽象 地 
表示 为 RCU) ,其 中 RR 表示 关系 名 ,例如 用 人 岗位 表 ;U 表示 属性 集合 ,例如 ,( 岗位 编号 ， 
岗位 名 称 ,… ,邮政 编 码 ) 。 

11. 关系 子 模式 

关系 子 模式 是 对 用 户 所 操作 数据 的 结构 描述 。 关 系 子 模式 与 具体 的 应 用 有 关 , 针 对 
不 同 的 目的 ,用 户 所 选择 的 属性 可 能 不 同 ,属性 也 可 能 来 自 多 个 关系 模式 。 

关系 子 模式 的 描述 格式 为 : 子 模式 名 (所 需 属性 名 表 ) ,属性 名 必须 是 某 个 关系 模式 
中 的 属性 或 运算 项 。 

【 例 2.2】 写 出 每 个 岗位 拟 聘 人 数 和 应 聘 人 数 两 个 子 模式 。 


拟 聘 人 数 (岗位 编号 ,岗位 名 称 , 人 数 ) 
应 聘 人 数 (岗位 编号 ,岗位 名 称 , Count (身份 证 号 )) 


子 模 式 “ 拟 聘 人 数 " 由 用 人 岗位 表 中 的 部 分 属性 构成 ,而 子 模式 “应 聘 人 数 " 中 的 属性 
来 自用 人 岗位 表 和 应 聘 人 员 基 本 情况 表 ( 身 份 证 号 属性 ) 两 个 关系 模式 。 其 中 Count 是 统 
计 记录 个 数 的 函数 运算 。 


12. 数据 操作 异常 
数据 操作 异常 是 指 对 表 中 的 数据 进行 操作 时 可 能 出 现下 列 3 种 情况 之 一 : 
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(1) 更 新 异常 。 是 指 修改 某 个 实体 的 数据 时 ,可 能 需要 同时 修改 涉及 该 实体 的 多 个 
记录 中 的 数据 ,否则 ,可 能 造成 数据 不 一 致 。 例 如 ,在 表 2-5 中 , 当 某 个 应 聘 人 员 获 得 新 的 
学 历时 ,必须 保证 修改 该 应 聘 人 员 所 涉及 记录 的 最 后 学 历 属性 值 ,否则 ,将 产生 矛盾 的 
数据 。 

(2) 插入 异常 。 是 指 由 于 缺少 主 属性 的 值 , 使 新 记录 无 法 添 到 表 中 。 例 如 ,由 于 岗位 
编号 是 表 2-5 中 的 主 属性 ( 不 能 为 空 ) ,因此 ,在 应 聘 人 员 申 报 岗位 之 前 ,不 能 将 其 相关 信 
息 添加 到 表 中 。 

(3) 删除 异常 。 是 指 删 除 某 些 记 录 时 ,可 能 导致 有 保留 价值 的 数据 丢失 。 例 如 ,如 果 
某 应 聘 人 员 暂 时 放弃 申报 任何 岗位 , 则 应 该 从 表 2-5 中 删除 该 应 聘 人 员 的 所 有 记录 ,但 这 
将 导致 丢失 该 应 聘 人 员 的 基本 信息 ( 如 身份 证 号 姓名 和 婚 否 等 ) 和 申报 痕迹 。 





2.3 属性 的 函数 依赖 关系 


一 个 关系 由 多 个 属性 构成 ,各 个 属性 之 间 往 往 存在 一 定 的 函数 依赖 关系 。 属 性 之 间 
的 某 些 函 数 依赖 关系 可 能 导致 数据 库 中 的 数据 重复 存储 ( 宛 余 ) 或 操作 异常 。 在 数据 库 
迪 辑 设计 过 程 中 ,主要 工作 是 分 析出 属性 之 间 的 函数 依赖 关系 ,以 便 规范 化 和 优化 数据 库 
中 的 关系 模式 。 


1. 函数 依赖 


设 有 关系 模式 R(U) ,X 和 YY 都 是 U 的 子 集 ( 部 分 属性 ) ,对 于 R 中 的 任意 两 个 元 组 
(记录 ) ,如 果 对 XX 的 投影 值 ( 即 对 应 的 属性 值 ) 相 等 , 则 对 了 的 投影 值 就 相等 。 将 XX 和 了 
的 这 种 关系 称 为 Y 函数 依赖 于 X, 或 称 X 函数 决定 了 , 记 为 XY。 

如 果 了 不 函数 依赖 半 , 则 记 为 XbY。 

所 谓 函 数 依赖 是 指 一 组 属性 X 的 值 可 以 决定 男 一 组 属性 Y 的 值 。 例 如 ,在 表 2-1 中 ， 
岗位 编号 能 决定 岗位 名 称 和 最 低 学 历 ,分 别 记 为 “岗位 编号 一 岗位 名 称 ” 和 “岗位 编 
号 一 最 低 学 历 ”。 在 表 2-5 中 ,身份 证 号 能 决定 姓名 , 记 为 “身份 证 号 一 姓名 ”"。 但 是 , 某 
些 属性 需要 多 个 属性 才能 唯一 确定 其 值 。 例 如 , 表 2-5 中 的 笔试 成 绩 和 面试 成 绩 都 需要 
身份 证 号 与 岗位 编号 共同 确定 其 值 , 即 * (身份 证 号 ,岗位 编号 ) 一 笔试 成 绩 " 和 ”*( 身份 证 
号 ,岗位 编号 ) 一 面试 成 绩 ” 。 

正 像 数学 中 函数 y =f(x) 一 样 ,给 定 x 值 后 ,y 的 值 也 就 唯一 确定 了 。 属 性 之 间 是 否 
存在 函数 依赖 关系 ,完全 由 数据 的 语义 决定 。 例 如 ,如 果 规 定 每 个 应 聘 人 员 只 能 开设 一 个 
QQ 账号 ,那么 “身份 证 号 一 QQ 账号 ”; 若 允许 一 个 应 聘 人 员 使 用 多 个 QQ 账号 , 则 “身份 
证 号 ArQQ 账号 ”。 

【 例 2.3】 根据 表 2-4 的 数据 语义 ,从 应 聘 人 员 基 本 情况 表 中 ( 表 2-5) 分 析出 9 个 函 


人 身份 证 号 一 姓名 
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@ 身份 证 号 一 最 后 学 历 

@ (身份 证 号 ,岗位 编号 ) 一 笔试 成 绩 

图 (身份 证 号 ,岗位 编号 ) 一 面试 成 绩 

@ (身份 证 号 ,岗位 编号 ) 一 (笔试 成 绩 ,面试 成 绩 ,笔试 成 绩 比 例 ) 

@ (身份 证 号 ,岗位 编号 ) 一 总 分 

@ 笔试 成 绩 ,面试 成 绩 ,笔试 成 绩 比 例 ) 一 总 分 

(身份 证 号 ,岗位 编号 ) 一 姓名 

@ (身份 证 号 ,岗位 编号 ) 一 最 后 学 位 

在 表 2.5 中 ,一 个 应 聘 人 员 可 以 申报 多 个 岗位 , 故 可 有 多 个 面试 成 绩 和 笔试 成 绩 , 因 
此 有 “身份 证 号 心 面试 成 绩 " 且 “身份 证 号 笔试 成 绩 "。 同 样 ,一 个 岗位 也 可 能 有 多 个 应 
聘 人 员 , 即 对 应 多 个 面试 成 绩 和 笔试 成 绩 , 故 有 “岗位 编号 \, 面 试 成 绩 " 且 “岗位 编号 A 笔 
试 成 绩 ”。 

2. 完全 函数 依赖 

在 关系 模式 R(U) 中 , 设 X 和 Y 是 两 个 不 同 的 属性 集合 ,有 XY, 对 于 XX 的 任意 真子 


集 久 ,都 及-wY, 则 称 Y 完 全 范 数 依赖 于 X, 记 为 XY。 

在 例 2.3 中 ,前 7 个 函数 依赖 关系 都 是 完全 函数 依赖 ,而 后 两 个 不 是 完全 函数 依赖 

属性 之 间 的 完全 函数 依赖 关系 表示 关系 模式 中 属性 之 间 的 依存 程度 。 一 般 地 讲 , 如 
果 一 个 关系 模式 中 的 每 个 非 主 属性 都 完全 函数 依赖 于 关键 字 , 则 表示 该 关系 模式 设计 得 
比较 规范 ,合理 。 

3. 部 分 函数 依赖 

在 关系 模式 RU) 中 , 设 X 和 了 是 两 个 不 同 的 属性 集合 ,有 xyY, 但 了 不 完全 函数 依 
赖 于 X, 则 称 了 部 分 函数 依赖 于 X, 记 为 X- 二 7。 

例 2.3 分 析出 来 的 函数 依赖 关系 中 ,由 于 “身份 证 号 一 姓名 ", “身份 证 号 一 最 后 学 
历 " , 故 有 * (身份 证 号 ,岗位 编号 )- 二 姓名 "和 * (身份 证 号 ,岗位 编号 ) -二 ,最 后 学 历 "。 

4. 传递 函数 依赖 

在 关系 模式 R(U) 中 , 设 X 了 和 2 是 不 同 的 属性 集合 ,如 果 X > 7, 一 2 但 了 YAX 且 
7 不 是 工 的 子 集 , 则 称 Z 传递 函数 依赖 于 X。 

在 例 2.1 的 用 人 岗位 表 的 关系 模式 中 ,岗位 编号 一 公司 名 称 ", “公司 名 称 一 公司 地 
址 ” ,而 “公司 名 称心 岗位 编号 ” ,因此 ,公司 地 址 传递 函数 依赖 于 岗位 编号 。 

在 例 2.3 的 函数 依赖 关系 中 ,由 于 有 “(身份 证 号 ,岗位 编号 ) 一 (笔试 成 绩 ,面试 成 
绩 , 笔 试 成 绩 比 例 )” 和 “(笔试 成 绩 ,面试 成 绩 , 笔 试 成 绩 比 例 ) 一 总 分 " ,并 且 “ (笔试 成 
绩 ,面试 成 绩 ,笔试 成 绩 比 例 )-w( 身份 证 号 ,岗位 编号 )”, 因 此 总 分 传递 函数 依赖 于 ( 身份 
证 号 ,岗位 编号 ) 。 
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总 之 ,在 一 个 关系 模式 ( 表 ) 中 , 非 主 属性 对 关键 字 的 完全 或 部 分 函数 依赖 关系 构成 
了 函数 依赖 关系 的 完全 集 , 某 个 传递 函数 依赖 关系 可 能 兼备 完全 或 部 分 函数 依赖 关系 。 
例如 ,在 表 2-5 中 ,总 分 既 传 递 函数 依赖 于 ( 身份 证 号 ,岗位 编号 ) ,又 完全 函数 依赖 于 ( 身 
份 证 号 ,岗位 编号 ) 。 

如 果 表 中 存在 某 些 非 主 属性 部 分 或 传递 函数 依赖 于 关键 字 , 则 该 表 中 一 定 存在 可 优 
化 的 元 余数 据 项 或 异常 操作 。 


2.4 关系 模式 的 规范 化 


某 些 属性 的 函数 依赖 关系 可 能 会 引发 数据 元 余 和 操作 异常 等 问题 。 关 系 模式 规范 化 
是 关系 数据 库 迎 辑 设计 的 主要 内 涵 ,实质 是 对 数据 表 进 行 优 化 。 其 主要 目标 是 减少 数据 
宛 余 ,便于 数据 操作 ,提高 系统 时 空 效率 ,满足 实际 应 用 要 求 。 

设计 关系 模式 ( 表 ) 的 基本 原则 是 实体 型 一 表 化 , 即 一 个 实体 型 或 关联 对 应 一 个 关系 
模式 。 关 系 模式 的 规范 化 方法 是 : 对 不 符合 要 求 的 关系 模式 进行 投影 分 解 ,去 掉 宛 余 属 
性 ,由 此 可 能 得 到 更 多 的 .比较 理想 的 关系 模式 。 关 系 模 式 的 分 解 必须 是 无 损 的 , 即 对 规 
范 化 后 的 关系 模式 进行 自然 连接 后 可 以 还 原 到 原 有 的 关系 模式 。 

关系 模式 规范 化 的 理论 就 是 研究 关系 模式 中 属性 之 间 的 函数 依赖 关系 对 关系 模式 性 
能 的 影响 ,探讨 关系 模式 应 该 具备 的 性 质 , 为 关系 模式 规范 化 提供 基本 准则 。 

范式 (Normal Form) 是 满足 某 种 特定 要 求 的 关系 模式 的 集合 ,也 是 衡量 关系 模式 规范 
化 的 标准 。 范 式 表 示 关 系 模式 的 规范 化 程度 。 目 前 主要 有 第 一 范式 (1NF) .第 二 范式 
(2NF) .第 三 范式 (3NF) 、BCNF( Boyce-Code Normal Form) .第 四 范式 (4NF) 和 第 五 范 
式 (5NF) ,由 第 一 范式 (1NF) 到 第 五 范式 (5SNF ) 要求 条 件 逐 渐 增 强 。 


2.4.1 第 一 范式 


在 关系 数据 库 中 ,将 每 个 属性 都 具有 原子 性 ( 即 一 个 属性 仅 表示 一 个 数据 语义 ) 的 关 
系 模式 集合 称 为 第 一 范式 ( 简 记 为 INF) 。 将 第 一 范式 中 的 每 个 成 员 R 都 称 为 规范 化 的 
关系 模式 ,也 称 R 为 第 一 范式 的 关系 模式 。 

关系 数据 库 中 的 每 个 表 必 须 符合 某 级 范式 的 要 求 。 第 一 范式 是 对 表 的 最 基本 要 求 ， 
也 就 是 说 ,一 个 数据 表 最 起 码 应 该 满足 以 下 要 求 : 是 二 维 表 ;有 主 关键 字 ; 每 个 属性 都 具 
有 原子 性 。 


1. 表 的 规范 化 


由 于 普通 表格 的 格式 种 类 繁多 ,很 难 找到 一 种 通用 的 方法 将 其 转换 成 规范 化 的 表 。 
常规 的 做 法 是 拆 分 多 维 表 ( 如 表 2-2 所 示 ) ,使 其 成 为 二 维 表 ( 如 表 2-5 所 示 ) ,必要 时 可 以 
将 一 个 普通 表格 分 解 成 多 个 二 维 表 。 在 表格 转换 过 程 中 ,还 要 考虑 关系 中 属性 的 原子 性 、 
主 属性 的 非 空 性 等 因素 。 
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表 2-2 显然 不 是 二 维 表 ,因此 它 不 是 第 一 范式 。 将 其 整理 成 二 维 表 的 方法 是 : 去 掉 
“基本 信息 ”和 ”考核 成 绩 "两 个 子 表 标题 行 ,并 将 子 表 中 各 列 标题 ( 如 身份 证 号 和 笔试 成 
等 ) 升级 为 主 表 的 列 标题 ;将 应 聘 人 员 的 数据 行 纵向 展开 ,每 个 岗位 占 一 行 。 如 果 某 个 应 
聘 人 员 同 时 申报 多 个 岗位 , 则 其 “基本 信息 ”在 多 行 中 重复 存储 。 

在 二 维 表 的 基础 上 ,还 要 将 具有 多 重 数据 语义 的 列 (如 地 址 及 邮政 编码 ) 分 割 成 多 个 
独立 数据 语义 的 列 ( 如 通信 地 址 和 邮政 编码 两 列 ) ,最 后 将 普通 表格 整理 成 符合 第 一 范式 
条 件 要求 的 关系 模式 ,如 表 2-5 所 示 。 

【 例 2.4】 写 出 表 2-5 对 应 的 第 一 范式 关系 模式 。 

应 聘 人 员 基 本 情况 表 (身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 , 最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 编码 ， 

Fmail 账号 ,00 账号 ,固定 电话 ,移动 电话 ,个 人 简历 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,总 

分 ) 


2. 第 一 范式 可 能 存在 的 问题 


往往 仅 满足 第 一 范式 要 求 的 关系 模式 并 不 理想 ,可 能 存在 数据 元 余 、 操 作 异 常 等 问 
题 。 例 如 ,在 表 2-5 中 仍然 存在 下 列 问题 : 

(1) 数据 元 余 。 当 某 个 应 聘 人 员 申 报 多 个 岗位 时 ,基本 信息 (如 身份 证 号 、 姓 名 和 个 
人 简历 等 ) 需 要 多 次 重复 存储 , 即 产 生 大 量 的 元 余数 据 。 

(2) 插入 异常 。 在 应 聘 人 员 申 报 岗位 之 前 ,无 法 将 其 基本 信息 添加 到 表 中 。 

(3) 更 新 异常 。 当 应 聘 人 员 的 婚姻 状态 、 最 后 学 位 、 通 信 地 址 .Email 账号 .QQ 账号 、 
固定 电话 ,移动 电话 或 个 人 简历 之 一 发 生变 化 时 ,需要 修改 该 应 聘 人 员 的 多 个 记录 ,否则 ， 
将 造成 数据 的 不 一 致 性 。 

(4) 删除 异常 。 当 应 聘 人 员 暂 时 取消 或 放弃 申报 时 ,无 法 保留 其 基本 信息 。 


3. 问题 存在 的 主要 原因 


在 表 2.5 中 ,( 身份 证 号 ,岗位 编号 ) 是 关键 字 , 由 于 有 “身份 证 号 一 姓名 "身份 证 
号 一 个 人 简历 "等 函数 依赖 关系 ,使 得 “(身份 证 号 ,岗位 编号 ) 一 ,姓名 "(身份 证 号 ， 
岗位 编号 )- 一 ,个 人 简历 "等 本 数 依赖 关系 存在 , 即 存在 非 主 属性 (姓名 个 人 简历 等 ) 部 分 
函数 依赖 于 关键 字 ( 身 份 证 号 ,岗位 编号 ) 。 这 样 的 一 些 部 分 函数 依赖 关系 导致 表 中 存在 
大 量 的 数据 宛 余 和 操作 异常 。 





2.4.2 第 二 范式 


关系 模式 R 属于 第 一 范式 ,如 果 R 中 的 任何 非 主 属性 都 完全 函数 依赖 于 关键 字 , 则 
称 关系 模式 R 属于 第 二 范式 ( 简 记 为 2NF)。 

对 第 二 范式 关系 模式 的 另 一 种 解释 是 : 在 第 一 范式 的 基础 上 ( 即 属性 具有 原子 性 )， 
如 果 再 消除 非 主 属性 对 关键 字 的 部 分 函数 依赖 关系 , 则 就 规划 成 第 二 范式 。 
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第 2 章 数据 库 逻 辑 和 设计 及 数据 库 系统 结构 


1. 第 二 范式 的 关系 模式 规范 化 


根据 设计 关系 模式 的 基本 原则 “实体 型 一 表 化 ” , 按 实 体型 进行 投影 分 解 第 一 范式 ， 
消除 非 主 属性 对 关键 字 的 部 分 函数 依赖 关系 ,使 其 分 解 成 多 个 第 二 范式 。 

【 例 2.5】 将 表 2-5 规范 化 成 第 二 范式 。 

表 2-5 总 体 描述 了 应 聘 人 员 和 岗位 考核 两 类 实体 ,岗位 考核 实体 型 也 表达 了 应 聘 人 
员 与 岗位 之 间 的 关联 。 按 照 这 两 个 实体 型 投影 分 解 后 的 第 二 范式 关系 模式 如 下 : 

应 聘 人 员 表 (身份 证 号 ,姓名 , 婚 和 否 , 最 后 学 历 , 最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 编码 ,Email 账 

号 ,QQ 账号 ,固定 电话 ,移动 电话 ,个 人 简历 ) 

岗位 成 绩 表 (身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,总 分 ) 

表 2-5 分 解 后 的 结果 如 表 2-6 和 表 2-7 所 示 。 

表 2-7 岗位 成 绩 表 (第 二 范式 ) 














身份 证 号 岗位 编号 资格 审核 笔试 成 绩 面试 成 绩 总 分 
229901199503121538 A0002 通过 80 85 82 
229901199503121538 B0002 通过 90 85 89 
119801199210011321 A0001 通过 35 90 80 




















2. 验证 第 二 范式 的 关系 模式 


依据 表 2-3 中 的 语义 分 析 , 身份 证 号 是 表 2-6 的 关键 字 ; ( 身份 证 号 ,岗位 编号 ) 是 
表 2-7 的 关键 字 。 并 且 两 个 表 中 的 任何 非 主 属性 与 关键 字 都 是 完全 函数 依赖 关系 ,因此 ， 
这 两 个 关系 模式 都 属于 第 二 范式 ,并 且 在 应 聘 人 员 基 本 情况 表 中 (如 表 2-5 所 示 ) 存 在 的 
一 些 问题 一 定 程度 上 得 到 了 解决 。 

例如 ,一 个 应 聘 人 员 即 使 申报 多 个 岗位 ,在 表 2-6 中 也 只 保存 其 一 个 数据 记录 ,减少 
了 数据 元 余 ; 当 修 改 应 聘 人 员 的 基本 信息 (如 姓名 、 移 动 电话 号 码 或 个 人 简历 等 ) 时 ,只 需 
要 修改 一 个 数据 记录 即 可 ;应 聘 人 员 申报 前 ,可 以 先 输 入 其 基本 信息 (如 身份 证 号 .姓名 
等 ) ;应 聘 人 员 暂 时 放弃 申报 时 ,可 以 保留 其 基本 信息 。 因 此 ,在 表 2-6 和 表 2-7 中 ,减少 
了 数据 元 余 和 操作 异常 现象 。 

【 例 2.6】 写 出 以 身份 证 号 为 关键 字 , 自然 连 接 表 2-6 和 表 2-7 的 SQL( Structured 
Query Language ,结构 化 查询 语言 ) 语 句 。 

Select 应 聘 人 员 表 .身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 ,最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 编码 ， 

Email 账号 ,09 账号 ,固定 电话 ,移动 电话 ,个 人 简历 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,总 

分 From 应 聘 人 员 表 ,岗位 成 绩 表 Where 应 聘 人 员 表 .身份 证 号 -岗位 成 绩 表 .身份 证 号 

通过 此 例 可 以 看 出 , 表 2-6 和 表 2-7 的 自然 连接 可 以 生成 应 聘 人 员 基 本 情况 表 ( 如 
表 2-5 所 示 ) ,由 此 可 以 验证 投影 分 解 后 的 两 个 关系 模式 一 一 应 聘 人 员 表 和 岗位 成 绩 表 是 
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对 应 聘 人 员 基 本 情况 表 的 无 损 分 解 。 

从 上 述 分 析 的 结果 总 体 来 看 ,第 二 范式 与 第 一 范式 的 关系 模式 比较 ,降低 了 数据 元 余 
度 ,减少 了 一 些 数 据 操作 异常 。 但 这 并 不 意味 着 第 二 范式 的 关系 模式 就 完全 消除 了 数据 
元 余 和 操作 异常 ,其 实 这 些 问 题 可 能 仍然 存在 ,只 是 程度 有 所 降低 。 例 如 ,在 岗位 成 绩 表 
中 (如 表 2-7 所 示 ) ,依据 表 2-4 中 的 数据 语义 分 析 , 其 中 总 分 是 由 笔试 成 绩 面试 成 绩 和 
笔试 成 绩 比 例 ( 在 表 2-1 用 人 岗位 表 中 )3 个 属性 的 值 计算 所 得 到 的 结果 , 故 总 分 属于 重 
复 存储 ( 宛 余 ) 的 属性 ,因此 ,关系 模式 还 有 进一步 规范 化 的 余地 。 


2.4.3 第 三 范式 


关系 模式 R 属于 第 二 范式 (也 属于 第 一 范式 ) ,如 果 其 中 所 有 非 主 属性 对 任何 关键 字 
都 不 存在 传递 函数 依赖 关系 , 则 称 关系 模式 R 属于 第 三 范式 ( 简 记 为 3NF) 。 

第 三 范式 实际 是 从 第 一 范式 消除 非 主 属性 对 关键 字 的 部 分 函数 依赖 和 传递 函数 依赖 
关系 而 得 到 的 关系 模式 。 

在 用 人 岗位 表 中 ,由 于 公司 地 址 传递 函数 依赖 于 岗位 编号 ,因此 ,“ 用 人 岗位 表 ( 岗位 
编号 ,岗位 名 称 , 最 低 学 历 , 最 低 学 位 ,人 数 , 年 龄 上 限 ,年 薪 , 笔 试 成 绩 比 例 ,笔试 日 期 , 聘 
任 要 求 ,公司 名 称 ,公司 地 址 ,邮政 编码 )" 不 属于 第 三 范式 。 

同样 ,在 “岗位 成 绩 表 ( 身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,总 分 )” 
关系 模式 中 ,由 于 总 分 属性 传递 函数 依赖 于 关键 字 ( 身份 证 号 ,岗位 编号 ) ,因此 该 关系 模 
式 也 不 属于 第 三 范式 。 

将 关系 模式 由 第 二 范式 规范 到 第 三 范式 的 方法 仍然 是 对 关系 模式 进行 投影 分 解 成 多 
个 关系 模式 ,或 直接 消除 非 主 属性 对 关键 字 的 传递 函数 依赖 关系 。 

【 例 2.7】 用 投影 分 解 的 方法 将 用 人 岗位 表 ( 如 表 2-1 所 示 ) 规 范 化 成 第 三 范式 。 

根据 设计 关系 模式 “实体 型 一 表 化 "的 规范 化 原则 ,将 岗位 和 公司 两 个 实体 型 分 解 成 
如 下 两 个 关系 模式 ,如 表 2-8 和 表 2-9 所 示 。 

岗位 表 (岗位 编号 ,岗位 名 称 ,最 低 学 历 ,最 低 学 位 ,人 数 ,年 龄 上 限 ,年 薪 , 笔 试 成 绩 比 例 ,笔试 日 

期 ,聘任 要 求 ,公司 名 称 ) 

公司 表 (名 称 ,地 址 ,注册 日 期 ,注册 人 数 ,邮政 编码 ,简介 ) 
表 2-8 岗位 表 ( 第 三 范式 ) 























铀 | 多 区 | 双打 | 学 全 | 人 数 | 下 | 年 村 | 续 比 全 | 笔 研 日 期 | 。 聘任 要 求 。 | 公司 名 称 
A0001 本 科 | 学 士 | 1 24 8 70 |2017.1.14 人 
A0002 ee 专科 3 24 7 70 |2017.1.15 es 人 
BO001 1 博士 | 博士 | 1 | 30 | 2 | 50 |2017.1.14 ee 
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表 2-9 公司 表 ( 第 三 范式 ) 

















公司 名 称 地 址 注册 日 期 注册 人 数 邮政 编码 
工商 前 进 支行 长 春 市 高 新 区 1991 年 10 月 1 日 20 130012 
腾飞 总 公司 北京 市 中 关 村 2001 年 7 月 1 日 2000 100201 
医大 一 院 长 春 市 朝阳 区 1948 年 1 月 1 日 5000 130012 














用 下 列 SQL 语句 可 以 还 原 回 原来 的 关系 模式 ( 如 表 2-1 所 示 ) : 


Select 岗位 编号 ,岗位 名 称 ,最 低 学 历 , 最 低 学 位 , 人数, 年龄 上 限 ,年 薪 , 笔 试 成 绩 比 例 ,笔试 日 期 ， 
聘任 要 求 , 名 称 ,地 址 ,邮政 编码 From 用 人 岗位 表 , 公 司 表 Where 用 人 岗位 表 . 公 司 名 称 = 公司 表 . 
名 称 
【 例 2.8】 去 掉 岗 位 成 绩 表 ( 如 表 2-7 所 示 ) 中 的 宛 余 属性 总 分 ,规范 化 成 第 三 范式 
的 关系 模式 ,如 表 2-10 所 示 。 
岗位 成 绩 表 (身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ) 
表 2-10 岗位 成 绩 表 ( 第 三 范式 ) 











身份 证 号 岗位 编号 资格 审核 笔试 成 绩 面试 成 绩 
229901199503121538 A0002 通过 80 85 
229901199503121538 BO002 通过 90 85 
119801199210011321 A0001 通过 75 90 

















通过 下 列 SQL 语句 可 以 生成 原来 的 关系 模式 : 

select 身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ,笔试 成 绩 * 笔试 成 线 比例 /100 4 面 

试 成 绩 * (100 -笔试 成 绩 比 例 ) /100 As 总 分 From 岗 位 成 绩 表 ,岗位 表 Where 岗位 成 绩 表 . 岗 位 纺 

号 -岗位 表 .岗位 编号 

在 关系 数据 库 的 逻辑 设计 过 程 中 ,前 三 级 范式 主要 研究 非 主 属性 与 关键 字 的 函数 依 
赖 关系 对 关系 模式 规范 化 程度 的 影响 。 一 般 来 讲 ,关系 模式 规范 化 到 第 三 范式 就 比较 
理想 。 

如 果 还 需要 进一步 解决 第 三 范式 关系 模式 中 的 数据 元 余 和 操作 异常 问题 , 则 需要 深 
入 研究 主 属性 与 关键 字 的 某 些 函 数 依赖 关系 对 关系 模式 规范 化 的 影响 ,继续 学 习 BCNF、 
第 四 和 第 五 范式 。 从 实际 应 用 的 角度 出 发 ,本 书 不 再 讲述 后 3 种 范式 。 

总 之 ,关系 数据 库 中 的 关系 模式 ( 表 ) 必须 满足 某 级 范式 的 要 求 ,关系 模式 的 范式 级 
别 越 高 ,关系 数据 库 中 的 数据 宛 余 度 越 小 ,数据 操作 异常 率 越 低 , 随 之 产生 的 关系 模式 
( 表 ) 的 数量 也 就 越 多 。 这 就 意味 着 在 实现 数据 查询 .统计 时 增加 了 表 之 间 的 连接 操作 次 
数 ,也 加 大 了 系统 的 时 间 开销 。 

【 例 2.9】 查询 每 个 应 聘 人 员 的 身份 证 号 .姓名 .岗位 名 称 和 总 分 。 
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通过 第 一 范式 的 关系 模式 (如 表 2-1 和 表 2-5 所 示 ) ,用 下 列 两 个 表 连 接 的 SQL 语句 
实现 查询 : 

Select 身份 证 号 ,姓名 ,岗位 名 称 , 总 分 From 应 聘 人 员 基 本 情况 表 , 岗 位 表 Where 应 聘 人 员 基 本 情 

而 通过 第 三 范式 的 关系 模式 ,要 用 下 列 3 个 表 连 接 的 SQL 语句 才能 实现 查询 : 

Select 应 聘 人 员 表 .身份 证 号 ,姓名 ,岗位 名 称 ,笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (100 

笔试 成 绩 比例 ) /100 as 总 分 From 应 聘 人 员 表 ,岗位 成 绩 表 , 岗 位 表 Where 应 聘 人 员 表 .身份 证 号 

- 疯 位 成 绩 表 .身份 证 号 And 岗位 成 绩 表 .岗位 编号 - 讽 位 表 .岗位 编号 

显然 ,用 第 三 范式 的 关系 模式 实现 数据 查询 , 表 之 间 的 连接 条 件 比 较 复 杂 , 系 统 检索 
数据 所 需要 的 时 间 也 较 长 。 

由 本 例 可 以 看 出 ,关系 模式 的 级 别 不 一 定 越 高 越 好 ,每 级 范式 各 有 利弊 。 因 此 ,关系 
模式 规范 化 的 基本 要 求 是 由 低 到 高 ,逐步 规范 ,权衡 利 浆 ,适可而止 。 通 常 以 满足 第 三 范 
式 为 基本 要 求 。 


2.5 数据 编码 对 关系 模式 的 作用 


在 人 们 的 各 项 事务 处 理 中 ,编码 信息 无 处 不 在 。 身 份 证 号 ,学 号 文件 号 (有 关 部 门 
颁发 的 文件 ) .图 书号 .汽车 牌照 号 .列车 车 次 .商品 条 形 码 .信用 卡号 和 股票 代码 等 都 是 
编码 信息 , 它 在 人 类 的 各 种 活动 和 计算 机 数据 处 理 过 程 中 起 着 重要 作用 。 


2.5.1 数据 编码 


数据 编码 是 表示 事物 对 象 的 一 种 符号 ,是 对 象 在 某 一 范围 内 的 唯一 标识 。 多 数 数据 
编码 中 仅 包含 数字 .英文 字母 , 减 号 或 /( 如 身份 证 号 ,图书 号) ;有 些 编码 中 也 包含 汉字 
(如 汽车 牌照 号 .文件 号 ) 。 总 体 来 看 ,数据 编码 要 短 于 对 应 的 对 象 名 称 。 从 数据 编码 的 
复杂 程度 来 分 ,大 体 可 分 为 单 体 编码 和 复合 编码 两 种 。 


1. 单 体 编码 


单 体 编码 通常 只 起 标识 对 象 的 作用 ,编码 中 各 位 没有 特定 含义 ,通常 这 类 编码 有 国家 
统一 标准 。 例 如 ,在 性 别 码 中 ,1 表示 男 ,2 表示 女 ; 在 民族 码 中 ,01 表示 汉族 ,11 表示 满 
族 ,56 表示 基诺 族 等 ;在 省 市 码 中 ,11 表示 北京 ,22 表示 吉林 ,37 表示 山东 等 。 在 实际 应 
用 中 ,通常 对 可 穷 举 的 数据 域 进行 编码 。 在 编码 时 ,尽量 采用 国家 或 相关 部 门 的 统一 标 
准 ,以 便 数据 在 较 大 范围 内 具有 通用 性 和 兼容 性 。 


2. 复合 编码 
复合 编码 也 起 标识 对 象 的 作用 ,但 编码 由 若干 段 组 成 ,每 段 都 表示 不 同 的 含义 。 常 见 
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的 分 段 方法 有 按 位 分 段 ( 如 身份 证 号 ) 和 通过 分 隔 符 ( 如 - 或/“) 分 段 (如 图 书 或 期 刊 
号 ) 。 数 据 编码 按 位 分 段 更 适合 计算 机 数据 处 理 ,而 计算 机 处 理 其 他 分 段 法 的 数据 编 
码 要 相对 复杂 一 些 。 因 此 ,在 设计 数据 库 时 ,如 果 需 要 对 数据 进行 复合 编码 ,尽量 采用 
按 位 分 段 法 。 


2.5.2 数据 编码 的 作用 


在 设计 数据 库 时 ,充分 利用 数据 的 单 体 编码 可 以 节省 存储 空间 ;充分 利用 数据 的 复合 
编码 能 进一步 规范 关系 模式 ,减少 数据 宛 余 。 

【 例 2.10】 对 人 才 招 聘 数据 库 中 的 学 历 和 学 位 进行 编码 。 

学 历 : 用 1 位 编码 。1 表示 高 中 及 以 下 ;2 表示 大 专 ;3 表示 本 科 ;4 表示 研究 生 ;5 表示 博士 。 

学 位 : 用 1 位 编码 。1 表示 无 学 位 ;2 表示 学 士 ;3 表示 双 学 士 ;4 表示 硕士 ;5 表示 博士 。 

【 例 2.11】 用 MySQL 系统 函数 从 我 国 第 二 代 身 份 证 号 中 获取 户口 所 在 地 的 省 市 编 
码 .地 区 编码 .县 编码 .出 生日 期 和 性 别 。 

省 市 编码 才 eft (身份 证 号 ,2) 

地 区 编码 了 eft (身份 证 号 ,4) 

县 编码 了 eft (身份 证 号 ,6) 

出 生日 期 Mia (身份 证 号 ,7,8) 

性 别 二 ff (mid (身份 证 号 ,17,1)s2 -0，' 女 …' 男 9) 

我 国 第 二 代 身 份 证 号 由 18 位 组 成 ,其 中 第 17 位 为 性 别 位 ,奇数 为 男 ;偶数 为 女 。 由 
此 可 以 看 出 ,在 含有 身份 证 号 的 关系 模式 中 可 以 去 掉 户 口 所 在 地 .出 生日 期 和 性 别 属 性 ， 
需要 这 些 属性 值 时 可 以 从 身份 证 号 的 相关 位 置 上 获取 。 

从 例 2.11 可 以 看 出 ,数据 复合 编码 实际 上 是 多 个 属性 的 组 合 , 从 理论 上 讲 , 在 表 中 使 
用 数据 复合 编码 将 破坏 属性 的 原子 性 。 但 在 实际 应 用 中 ,从 操作 方便 和 节省 存储 空间 等 
实用 方面 综合 考虑 ,在 许多 数据 库 设计 中 ,宁可 突破 理论 规则 ,也 引用 数据 复合 编码 技术 。 

从 总 体 来 看 ,在 计算 机 事务 处 理 过 程 中 ,对 数据 库 中 的 数据 进行 编码 主要 有 如 下 3 个 
作用 : 

(1) 易于 信息 标准 化 ,提高 数据 的 准确 率 。 例 如 ,在 输入 性 别 信息 时 ,根据 个 人 习惯 
不 同 ,可 能 输入 男 .男士 或 先生 ,但 计算 机 难以 将 其 作为 相同 的 性 别处 理 ,为 数据 统计 分 析 
带 来 较 大 的 困难 。 采 用 数据 编码 (1 表示 男 ,2 表示 女 ) 便 不 会 发 生 类 似 的 问题 。 

(2) 充分 利用 数据 采集 技术 。 手 涂 卡 、 条 形 码 ,磁卡 和 1IC 卡 都 是 目前 信息 数字 化 的 
主要 手段 。 对 数据 编码 后 ,可 以 充分 采取 这 些 手 段 有 效 地 提高 计算 机 数据 采集 的 速度 和 
正确 率 。 

(3) 利于 提高 系统 的 时 空 效率 。 例 如 ,对 性 别 ,学历 ,学 位 .专业 和 公司 名 等 进行 编码 
均 可 以 减少 数据 量 ,节省 存储 空间 ,同时 能 提高 数据 处 理 ,检索 和 传输 的 速度 。 
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2.6 人才 招聘 数据 库 的 设计 


研究 关系 模式 规范 化 和 数据 编码 的 主要 目的 是 探讨 设计 数据 库 的 基本 方法 ,寻求 衡 
量 数据 库 质量 的 标准 ,为 设计 和 优化 数据 库 提供 理论 依据 。 

在 设计 实际 数据 库 的 过 程 中 ,要 综合 权衡 相关 理论 数据 语义 ,可行 性 操作 方便 性 和 
系统 时 空 效 率 等 方面 的 问题 ,往往 在 某 方面 可 能 要 做 出 一 些 牺牲 ,以 求 得 比较 理想 的 设计 


方案 。 


由 于 数据 库 的 应 用 目的 以 及 侧重 面 不 同 , 对 数据 库 中 关系 模式 ( 表 ) 规 范 化 的 结果 并 
不 唯一 。 以 表 2-1 和 表 2-2 为 基础 ,经 历 第 一 范式 ( 表 2-5) .第 二 范式 ( 表 2-7) 和 第 三 范式 
( 表 2-6、 表 2-8、 表 2.9、 表 2-10) 规 范 化 后 ,再 对 某 些 数 据 项 进行 编码 ,人 才 招 聘 ( RCZP) 数 
据 库 可 以 简化 为 4 个 表 , 共 同 构成 其 数据 库 模 式 。 


1. 岗位 表 ( GWB) 
岗位 表 的 关系 模式 是 


GWB (岗位 编号 ,岗位 名 称 ,最 低 学 历 , 最 低 学 位 ,人 数 ,年 龄 上 限 ,年 薪 , 笔 试 成 绩 比 例 ,笔试 日 期 , 聘 
任 要 求 ,公司 名 称 ) 


对 应 的 表 结 构 设 计 说 明 如 表 2-11 所 示 。 
表 2-11 GWB 表 结 构 设 计 说 明 






































字段 名 类 型 长 度 默认 值 说 明 
岗位 编号 Char 5 主 属性 ,也 是 主键 
岗位 名 称 VarChar 30 最 多 存储 15 个 汉字 
i ENum('1','2','3','4 ee 学 历 编码 : 1 无 要 求 ,2 专科 ,3 本 
最 低 学 历 。 |， ,5') 定义 : 3 | 科 ,4 研究生,5 博士 
A ENum (1' ,2',"3',"4', a 学 位 编码 : 1 无 ,2 学 士 ,3 双 学 士 ， 
要 代 尝 位 。 |) | 5) 定义 : 2 | 4 硕士 ,5 博士 
人 数 TinyInt 3 定义 : 1 
年 龄 上 限 TinyInt 2 定义 : 60 
年 薪 Mediumlnt 8 | 定义 : 36000 “| 年 工资 总 额 ,单位 为 人 民 币 元 
和 笔试 占 总 分 % ,默认 值 0, 表 示 不 需 
过 绩 ‘inyIni 和 : ES 
笔试 成 绩 比例 | TinyInt 3 | 定义 :0 要 笔试 
笔试 日 期 Date 
聘任 要 求 TinyText 如 专业 ,特长 ,笔试 内 容 等 要 求 
公司 名 称 VarChar 40 最 多 存储 20 个 汉字 
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2. 应 聘 人 员 表 ( YPRYB) 
应 聘 人 员 表 的 关系 模式 是 


YPRYB (身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 ,最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 编码 , Email 账号 ,QQ 
账号 ,固定 电话 ,移动 电话 ,密码 ,个 人 简历 ) 


对 应 的 表 结 构 设 计 说 明 如 表 2-12 所 示 。 
表 2-12 YPRYB 表 结 构 设计 说 明 












































字段 名 类 型 长 度 | 默认 值 说 明 

让 主 属 性 ,也 是 主键 。 由 身份 证 号 可 得 性 
身份 证 号 Char 18 别 和 出 生日 期 
姓名 VarChar 10 最 多 存储 5 个 汉字 
婚 否 Boolean 或 TinyInt 1 定义 : 0 |0 表示 未 婚 , 非 0 表示 已 婚 

ENon( U2 定 义 : “| 学 历 编码 : 1 无 ,2 专科 ,3 本 科 ,4 研究 
最 后 学 历 |5') 3 生 ,5 博士 

sa | Nam (UD 定 义 : “| 学 位 编码 : 1 无 ,2 学 士 ,3 双 学 士 ,4 硕 
最 后 学 位 |5') 2 上 ,5 博士 
所 学 专业 | VarChar 30 最 多 存储 15 个 汉字 
通信 地 址 | VarChar 50 最 多 存储 25 个 汉字 
邮政 编码 | Char 6 
Email 账号 | VarChar 30 
QQ 账号 VarChar 30 
固定 电话 VarChar 20 
移动 电话 VarChar 15 
密码 VarChar 10 

存储 字符 数 比 CHAR 和 VARCHAR 更 

个 大 杭 因 | Ynt 多 ,一 般 可 达 64KB 














3. 岗位 成 绩 表 ( GWCJB) 
岗位 成 绩 表 的 关系 模式 是 
GHCJB (身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ) 


对 应 的 表 结 构 设 计 说 明 如 表 2-13 所 示 。 
在 GWCJB 表 中 ,通过 表达 式 : 笔试 成 绩 x GWB. 笔试 成 绩 比例 /100 + 面试 成 绩 x 
(1 -GWB. 笔试 成 绩 比例 /100) 可 以 得 到 总 分 , 故 可 以 不 存储 总 分 属性 。 
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表 2-13 ”GWCJB 表 结 构 设 计 说 明 





























字段 名 类 型 长 度 | 默认 值 说 明 
身份 证 号 | Char 18 主 属 性 ,也 是 与 应 聘 人 员 表 (YPRYB) 建 立 关联 的 外 键 
岗位 编号 | Char S 主 属 性 ,也 是 与 岗位 表 (GWB) 建 立 关 联 的 外 键 
资格 审核 | Boolean 或 TinyInt 1 | 定义 : 0| 0 表示 未 通过 , 非 0 表示 通过 
笔试 成 绩 | TinyInt 3 | 定义 : 0| 0 表示 缺 考 或 0 分 
面试 成 绩 | TinyInt 3 | 定义 : 0| 0 表示 缺 考 或 0 分 
4. 公司 表 
公司 表 的 关系 模式 是 


公司 表 (公司 名 称 ,地 址 ,注册 日 期 ,注册 人 数 ,邮政 编码 ) 


对 应 的 表 结 构 设计 说 明 如 表 2-14 所 示 。 
表 2-14 ”公司 表 结构 设计 说 明 

















字段 名 类 型 长 度 默认 值 说 明 
公司 名 称 VarChar 40 主 属 性 ,也 是 关键 字 ,最 多 可 存储 20 个 汉字 
地 址 VarChar 50 通讯 地 址 ,最 多 可 存储 25 个 汉字 
注册 日 期 Date 官方 登记 日 期 
注册 人 数 SmallInt 二 定义 : 100 | 无 符号 整数 ,最 多 65 535 人 
邮政 编码 Char 6 














在 公司 表 中 ,可 以 对 公司 名 称 进行 编码 ,也 可 以 扩充 一 些 字段 ,如 公司 简介 ,注销 ( 记 
载 是 否 注销 ) 和 宣传 片 (存储 视频 ) 等 。 

总 之 ,上 述 岗位 表 (GWB) .应聘 人 员 表 (YPRYB) 、 岗 位 成 绩 表 (GWCJB) 和 公司 表 4 
个 关系 模式 共同 构成 了 人 才 招 聘 ( RCZP) 数据库 模式 。 岗 位 编号 和 身份 证 号 是 GWCJB 
的 两 个 主 属性 ,共同 组 成 主键 ;岗位 编号 是 GWB 的 主键 ;身份 证 号 是 YPRYB 的 主键 。 因 
此 ,岗位 编号 和 身份 证 号 也 是 GWCJB 的 两 个 外 键 。 公 司 名 称 是 公司 表 的 主键 ,也 是 岗位 
表 (GWB) 的 外 键 。 物 理 设计 数据 库 时 ,用 身份 证 号 实现 YPRYB 和 GWCJB 之 间 的 关联 ; 
通过 岗位 编号 实现 GWB 和 GWCJB 之 间 的 关联 ;用 公司 名 称 实现 公司 表 与 岗位 表 ( GWB) 
之 间 的 关联 。 


2.7 数据库 系统 结构 
数据 库 系统 ( DataBase System,DBS ) 是 指 存储 数据 库 的 计算 机 系统 , 它 由 计算 机 硬 


件 . 软 件 和 相关 人 员 组 成 。 计 算 机 硬件 搭建 了 系统 运行 和 存储 数据 库 的 环境 ;计算 机 软件 
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用 于 管理 .控制 和 分 配 计算 机 资源 ,建立 .管理 .维护 和 操作 数据 库 , 主要 包括 操作 系统 
(0S) .数据库 管 理 系统 (DBMS) 和 数据 库 (DB) 。 

DBS 的 核心 内 容 是 DB。 依据 数据 库 罗 辑 设 计 中 的 关系 模式 ,在 DBMS 控制 下 创建 
DB , 表 .主键 以 及 表 之 间 的 关联 , 称 为 数据 库 的 物理 设计 。 物 理 设计 的 主要 成 果 便 是 DB。 


2.7.1 数据 库 系统 的 三 层 模 式 


由 于 使 用 DB 的 各 类 人 员 ( 如 应 用 程序 用 户 数据 库 管理 及 设计 人 员 和 DBMS 研发 人 
员 等 ) 要 完成 的 任务 性 质 . 权 限 和 目的 不 同 , 他 们 以 不 同 的 视角 看 竺 和 操作 DB。 因 此 , 目 
前 所 使 用 的 DBS 都 具有 外 模式 (External Schema) 模式 (Schema) 和 内 模式 ( Internal 
Schema)3 层 结构 的 特征 ,如 图 2-3 所 示 。 


应 用 1 本 应 用 n 

















应 用 程序 及 用 户 0 te@ 
外 模式 1 可 外 模式 
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DBMS 及 研发 人 员 








Lo | 
图 2-3 数据 库 系统 的 结构 


1. 外 模式 


外 模式 也 称 用 户 模式 或 子 模式 ,是 数据 库 的 局 部 迎 辑 结构 ( 某 个 应 用 的 内 部 数据 结 
构 ) ,也 是 某 类 用 户 或 应 用 程序 使 用 的 局 部 数据 视图 ( 即 展示 数据 的 形式 ) 。 一 个 数据 库 
中 可 以 有 多 个 外 模式 ,一 般 一 类 应 用 对 应 一 个 外 模式 ,外 模式 与 数据 库 的 每 类 应 用 目的 及 
用 户 权限 有 关 。 一 般 由 应 用 程序 设计 人 员 构造 外 模式 ,用 户 通过 运行 应 用 程序 中 的 外 模 
式 操作 数据 库 中 的 数据 。 

在 关系 数据 库 中 ,关系 子 模式 的 集合 便 构 成 了 外 模式 。 在 例 2.2 中 , 拟 聘 人 数 和 应 聘 
人 数 两 个 关系 子 模式 可 以 构成 一 个 外 模式 。 


2. 模式 
模式 也 称 逻 辑 模式 或 概念 模式 ,以 数据 模型 为 基础 ,是 数据 库 中 全 局 逻辑 结构 和 所 有 
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用 户 的 公共 数据 视图 。 一 个 数据 库 中 只 有 一 个 模式 ,通常 由 数据 库 设计 员 通 过 数据 定义 
语言 (Data Definition Language,DDL) 设 计 , 由 数据 库 管 理 员 进 行 管理 。 

在 关系 数据 库 中 ,模式 与 数据 库 所 存储 的 事物 对 象 .关系 模式 规范 化 的 程度 密切 相 
关 , 是 关系 模式 在 DBS 中 的 具体 实现 ,通过 全 部 关系 模式 创建 的 表 集 合 构成 了 模式 ， 
此 ,通常 将 数据 库 与 模式 视 为 一 个 概念 。 例 如 ,岗位 表 (GWB) 应聘 人 员 表 (YPRYB) 、 岗 
位 成 绩 表 (GWCJB ) 和 公司 表 4 个 表 构成 了 人 才 招 聘 的 模式 (数据 库 ) 。 


3. 内 模式 


内 模式 也 称 存储 模式 或 物理 模式 ,用 于 描述 实体 在 物理 设备 上 的 存储 方式 和 组 织 形 
式 , 它 是 数据 库 在 外 存储 器 ( 如 磁盘 .光盘 .U 盘 等 ) 上 的 物理 存储 结构 ,如 顺序 结构 链 式 
结构 和 索引 结构 等 存储 方式 。 物 理 存 储 结构 不 仅 取决 于 模式 ,也 取决 于 0S( 如 Windows、 
Linux 等 ) 和 DBMS( 如 Access MySQL 等 ) 的 类 型 ,在 设计 DBMS 时 ,由 研发 人 员 依 据 0S 
定义 存储 方式 和 组 织 形 式 。 

一 个 数据 库 中 只 有 一 个 内 模式 。 在 关系 数据 库 中 ,通过 二 维 表 存 储 实体 型 及 其 关联 ， 
表 的 组 织 形式 是 记录 。 在 DBS 运行 过 程 中 ,内 模式 由 DBMS 和 0S 的 文件 系统 自动 管理 ， 
对 用 户 来 说 是 隐藏 的 ,因此 ,用 户 可 不 必 过 多 考虑 内 模式 。 


2.7.2 ”数据库 系统 的 二 级 映像 


所 谓 映 像 就 是 各 层 模式 之 间 数 据 转换 的 规则 。 数 据 库 系统 是 一 个 整体 , 且 内 部 3 层 
模式 结构 之 间 还 存在 着 某 种 依存 关系 ,为 了 确保 3 层 模式 结构 既 能 相互 独立 ,又 能 协调 一 
致 地 工作 ,数据库 系统 采用 两 级 映像 实现 各 层 模式 结构 之 间 的 数据 转换 和 联系 。 


1. 外 模式 /模式 映像 


外 模式 /模式 映像 实现 数据 的 局 部 逻辑 结构 ( 外 模式 ) 与 数据 的 全 局 好 辑 结构 (模式 ) 
的 转换 ,通常 定义 在 外 模式 内 。 例 如 ,用 SQL 语句 进行 描述 。 由 于 一 个 模式 可 以 产生 多 
个 外 模式 ,因此 ,一 个 数据 库 中 可 能 有 多 个 外 模式 /模式 映像 ,如 图 2-3 所 示 。 

当 数 据 库 的 模式 发 生变 化 时 ,如 增加 新 关系 模式 ( 表 ) .新 属性 、 修 改 属性 宽度 和 数据 
类 型 ,只 需要 调整 外 模式 /模式 映像 ,无须 修改 外 模式 及 应 用 程序 ,因此 ,保持 了 外 模式 与 
模式 之 间 的 逻辑 独立 性 ,由 此 保证 了 应 用 程序 与 数据 库 的 迎 辑 独立 性 。 


2. 模式 /内 模式 映像 


如 图 2-3 所 示 ,一 个 数据 库 中 只 有 一 个 模式 和 内 模式 ,因此 只 有 一 个 模式 /内 模式 映 
像 , 它 定义 了 模式 和 内 模式 之 间 数 据 转 换 的 规则 ,以 便 实 现 数据 的 全 局 逻辑 结构 与 存储 结 
构 的 转换 。 

通常 在 模式 内 定义 模式 /内 模式 映像 , 当 数据 库 的 存储 结构 发 生变 化 时 (如 Access 数 
据 库 转换 成 MySQL 数据 库 ) ,使 用 具体 的 DBMS 提供 的 相关 视图 或 SQL 的 DDL 语句 ,由 
数据 库 管理 员 对 模式 /内 模式 映像 做 对 应 的 调整 ,不 需要 改变 模式 ,使 得 模式 不 受 内 模式 
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变化 的 影响 , 即 ,模式 和 内 模式 保持 相对 独立 。 
2.7.3 数据 库 系统 的 运行 过 程 


当 用 户 或 应 用 程序 发 出 读 取 数 据 的 请 求 时 ,DBMS 利用 三 层 模式 和 二 级 映像 的 运行 
过 程 大 致 如 图 2-3 所 示 。 

(1) 用 户 或 应 用 程序 通过 外 模式 向 DBMS 发 出 读 取 数 据 的 请 求 , 请 求 命令 中 包含 表 
名 数据 项 名 (投影 ) 和 提取 记录 的 条 件 (筛选 ) 。 

(2) DBMS 依据 外 模式 /模式 映像 规则 ,检查 外 模式 正确 性 及 用 户 权限 ,如 果 通 过 检 
查 , 则 确定 模式 上 的 相关 信息 (如 表 名 ,数据 项 等 ) ,否则 拒绝 请 求 。 

(3) DBMS 依据 模式 /内 模式 映像 规则 ,确认 内 模式 上 的 相关 信息 (如 物理 位 置 数据 
项 等 ) 。 

(4) DBMS 向 操作 系统 发 出 读物 理 记录 的 请 求 。 

(5) 0S 从 外 存储 器 读 出 物理 记录 , 传 给 DBMS( 内 模式 ) 。 

(6) DBMS 再 依据 模式 /内 模式 映像 规则 ,将 数据 转换 成 模式 能 识别 的 逻辑 记录 。 

(7) DBMS 再 依据 外 模式 /模式 映像 规则 , 按 外 模式 格式 转换 数据 。 

(8) DBMS 将 数据 发 给 用 户 或 应 用 程序 。 

这 些 仅仅 是 应 用 程序 读 取 数据 库 中 数据 的 一 般 步 又 ,并 没有 涉及 有 关 细 节 。 例 如 , 当 
某 个 环节 操作 不 成 功 时 ,终止 读数 据 操作 ,系统 将 逐 层 反馈 消息 等 。 写 入、 修改 和 删除 数 
据 等 操作 与 上 述 操作 过 程 类 似 。 

总 之 ,数据 库 敢 辑 设计 的 主要 任务 是 为 物理 设计 建立 一 种 理论 模型 ,进一步 的 工作 还 
需要 选择 一 种 数据 库 管 理 系统 ,将 逻辑 设计 的 成 果 在 具体 的 数据 库 管理 系统 中 实施 一 一 
物理 设计 数据 库 。 





习 题 


一 、 填空 题 

1. 在 对 各 种 业务 进行 计算 机 处 理 之 前 ,需要 对 事物 的 特征 进行  、@@ 和 
”图 ”处 理 ,以便 将 客观 事物 的 _@ ”以 数据 的 形式 存储 。 

2. 数据 库 是 四 、 句 的 _@ 数据 的 集合 ,是 存储 _@_ 的 软件 工具 。 主 要 
内 容 是 _@ 、@ 以 及 表 之 间 的 @ 。 

3. 设计 数据 库 通常 包括 需求 分 析 概念 设计 、 @ 和 ”@@ 4 个 环节 。 规 范 化 数 
据 表 属于 _ 〇 ;建立 数据 表 间 关联 属于 _@ ;分析 业 务 流程 ,收集 .归纳 和 分 析 业 务 资 
料 属于 _@ ;建立 E-R 模型 属于 _@ 。 

4. 学 生 信息 数据 库 中 有 学 生 和 专业 两 个 表 。 学 生 表 存 储 学 号 、 姓 名 和 专业 码 , 如 
22159901 , 张 明 宇 和 020101 等 学 生 信息 ,学 号 不 能 重复 ;专业 表 存 储 专业 码 和 专业 名 称 ， 
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如 020101 和 经 济 学 等 专业 信息 ,不 允许 专业 码 重 复 。 在 此 数据 库 中 ， 中 ”是 实体 型 ， 
加 是 实体 名 ， @@， 是 实体 属性 ， @ 是 属性 值 ，( 是 学 生 表 的 主键 ， @ 是 专 
业 表 的 主键 ，@ 是 _@ 表 的 外 键 。 

5. 一 个 表 由 _Q@_ 和 _@_ 两 部 分 构成 。 表 用 于 存储 _@ ,一 行 数据 表示 一 
个 @ 。 

6. 在 关系 模式 XY( 学 院 码 , 学 院 名 ,学 院 地 址 ) 中 ,假设 所 有 学 院 都 不 重 名 ， 中 “可 
以 作为 关键 字 ,通常 将 _@ “作为 主 关键 字 ， @@ 是 主 属性 。 

7. 有 关系 模式 XS( 学 号 ,姓名 ,民族 码 ) 和 MZ( 民族 码 , 民 族 名 ) ,通常 学 号 是 四 
的 主 关 键 字 ;民族 码 是 _@_ 的 主 关键 字 , 是 _@ 的 外 键 。 

8. 在 关系 模式 XS( 学 号 ,姓名 ,民族 码 , 民 族 名 ) 中 ,学 号 是 主 关键 字 。_ 中 “与 主 关 
键 字 存在 传递 函数 依赖 ,相关 函数 依赖 是 : 学 号 一 @ 和 四 一 中 。 

9. 在 关系 模式 CZ( 月 份 ,职工 号 ,姓名 ,基本 工资 ,奖金 ,个 人 所 得 税 ) 中 ,每 月 发 放 一 
次 工资 ,个 人 所 得 税 是 基本 工资 和 奖金 的 计算 值 。 主 关键 字 是 _ 中 ;四 部 分 函数 依 
赖 于 关键 字 ， @) 完全 函数 依赖 于 关键 字 ， @_ 传 递 函数 依赖 于 关键 字 。 

10. 要 将 第 一 范式 的 关系 模式 规范 成 第 二 范式 ,应 该 消除 _Q(D 对 关键 字 的 _@@ ，; 
要 将 一 个 第 二 范式 的 关系 模式 规范 成 第 三 范式 ,应 该 消除 _(D 对 关键 字 的 _@® 。 

11. 根据 实体 型 一 表 化 的 数据 库 逻 辑 设计 基本 原则 ,关系 模式 “学 生 ( 学 号 ,姓名 ,出 
生日 期 ,民族 名 ,专业 名 ) "应 该 分 解 成 _ 中 “个 关系 模式 ,分 别 是 四 。 

12. 通常 说 第 一 范式 的 关系 模式 不 理想 ,理由 是 关系 模式 中 可 能 存在 _ 中 “和 
_ 加。 这 些 问题 主要 是 由 非 主 属性 对 关键 字 的 _@@ 和 ”@ 引起 的 。 

13. 在 第 一 范式 的 基础 上 ,需要 消除 关系 模式 中 QD 对 关键 字 的 _@ ”函数 依赖 
关系 ,才能 规划 成 ”@) 范式 的 关系 模式 。 

14. 在 第 二 范式 的 基础 上 ,需要 消除 关系 模式 中 QD 对 关键 字 的 _@ 函数 依赖 
关系 ,才能 规划 成 ”_@) 范式 的 关系 模式 。 

15. 在 设计 数据 库 时 ,用 数据 的 单 体 编码 可 以 _Q@D _; 用 数据 的 复合 编码 能 进一步 规 
范 关 系 模式 ,能 减少 数据 _@ _, 但 将 破坏 属性 的 _@) 。 

16. 在 关系 模式 XS( 学 号 ,姓名 ,性 别 码 ,身份 证 号 ,专业 码 , 民 族 码 ) 中 ,性 别 码 、 专 业 
码 和 民族 码 均 为 国家 标准 代码 。 (DD 是 单 体 编码 ， @ 是 复合 编码 。 

17. 在 关系 模式 ZG( 职工 号 ,姓名 ,性 别 ,政治 面貌 ,职称 ,工资 ) 中 ， 中 “可 作为 关 
键 字 ， @® 适合 数据 编码 。 

18. 数据 库 系 统 结构 中 分 _@D_ 层 模式 ,有 _®@ 级 映像 ,一 个 数据 库 中 有 _@ 个 
内 模式 、 @_ 个 模式 和 ”@ 个 外 模式 。 



































二 、 单 选 题 

1. ( ”) 是 有 组 织 \ 结 构 化 的 相关 联 数据 的 集合 ,是 存储 事物 特征 数据 的 软件 工具 。 
A. 数据 库 管理 系统 B. 数据 库 
C. 概念 模型 D. 关系 模式 


2. 在 设计 数据 库 过程 中 ,分 析 业 务 流程 ,搜集 和 整理 相关 业务 资料 属于 ( 中) 阶 
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段 ,建立 概念 模型 和 分 析 数 据 语义 属于 ( ”加 ) 阶段 ,关系 模式 规范 化 和 数据 编码 属于 


( 图 ) 阶 段 。 
A. 需求 分 析 B. 概念 设计 C. 逻辑 设计 D. 物理 设计 
3. ( ”Q@@ ) 是 建立 ,管理 和 维护 ( ”@@， ) 的 系统 软件 。 
A. OS B. DB C. DBMS D. E-R 
4. 空 表 是 指 ( 站 
A. 不 含 任何 信息 的 表 B. 只 有 记录 没有 结构 的 表 
C. 只 有 结构 没有 记录 的 表 D. 没有 主键 和 外 键 的 表 
5. 通过 ( ) 可 以 控制 表 中 记录 的 唯一 性 。 
A. 内 码 B. 外 键 C. 主 码 D. 非 主 属性 


6. 数据 库 迎 辑 设计 主要 解决 的 问题 是 ( )。 
A. 消除 数据 宛 余 ,避免 发 生 数据 异常 操作 
B. 增加 表 的 数量 ,减少 表 的 连接 次 数 
C. 缩小 每 个 表 的 体积 ,充分 利用 磁盘 碎片 
D. 降低 数据 元 余 ,减少 操作 异常 
7. 在 关系 模式 GP( 股东 代码 ,股东 名 ,股票 代码 , 持 有 数量 , 均 价 ) 中 ,股东 允许 重 名 ， 
一 个 股东 可 持 有 多 种 股票 ,( 。 ”) 可 作为 关键 字 。 


A. 股东 代码 B. 股票 代码 
C. (姓名 ,股票 代码 ) D. (股东 代码 ,股票 代码 ) 
8. 在 关系 模式 CJ( 学 号 ,课程 号 ,成 绩 ) 中 ,一 个 学 生 可 能 选 多 门 课程 , ( ) 是 主 关 
键 字 。 
A 学 号 B. 课程 号 
(学 号 ,课程 号 ) D. (课程 号 ,成 绩 ) 


9. pd KS( 学 号 ,姓名 ,课程 名 ,成 绩 ) 的 最 高 范式 是 (。”)。 
A. 第 一 范式 B. 第 二 范式 C. 第 三 范式 D. 第 四 范式 
10. 在 某 些 关系 模式 中 存在 数据 更 新 异常 问题 ,这 里 的 更 新 异常 是 指 ( 。 ” )。 
A. 修改 数据 后 无 法 存盘 
B. 对 数据 进行 了 保护 ,用 户 无 法 修改 
C. 修改 一 个 属性 值 时 可 能 要 修改 多 个 属性 的 值 
D. 修改 一 个 记录 时 可 能 要 修改 多 个 记录 
11. 在 某 些 关系 模式 中 存在 数据 插入 异常 问题 ,这 里 的 插入 异常 是 指 ( 。” )。 
A. 缺少 非 主 属性 的 值 ,不 能 增加 记录 
B. 缺少 主 属性 的 值 , 不 能 增加 记录 
C. 数据 库 太 小 ,无 法 执行 插入 操作 
D. 磁盘 已 满 ,无 法 执行 插入 操作 
12. 在 某 些 关 系 模式 中 存在 数据 删除 异常 问题 ,这 里 的 删除 异常 是 指 ( 。”)。 
A. 删除 记录 可 能 丢失 某 实体 信息 B. 删除 记录 将 导致 丢失 某 实体 型 
C. 删除 元 组 后 无 法 存盘 D. 删除 元 组 将 删除 其 他 表 
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13. 在 表 22 中 ,(， 中) 完全 函数 依赖 于 (身份 证 号 ,岗位 编号 ) ,( ”四 ) 传 递 函 
数 依赖 于 ( 身份 证 号 ,岗位 编号 ) 。 
A. 姓名 B. 最 后 学 历 C. 总 分 D. QQ 账号 
14. 在 第 二 范式 的 关系 模式 中 ,一 定 不 存在 ( 。” )。 
A. 主 属性 对 关键 字 的 部 分 函数 依赖 
B. 非 主 属性 对 关键 字 的 部 分 函数 依赖 
C. 主 属性 对 关键 字 的 传递 函数 依赖 
D. 非 主 属性 对 关键 字 的 传递 函数 依赖 
15. 在 关系 模式 规范 化 过 程 中 ,要 求 对 关系 模式 必须 无 损 分 解 ,所 谓 无 损 分 解 是 





指 (  )。 
A. 分 解 前 后 所 需 存储 空间 一 至 B. 分 解 前 后 属性 名 称 及 个 数 一 致 
C. 通过 自然 连接 可 以 还 原 D. 通过 等 值 连接 可 以 还 原 


16. 在 关系 模式 GZ( 职工 号 ,姓名 ,性 别 ,基本 工资 ,奖金 ,应 发 工资 ) 中 ,应 发 工资 等 
于 基本 工资 与 奖金 之 和 。( ”) 将 保留 原 功 能 而 降低 数据 元 余 度 。 
A. 增加 月 份 属性 B. 基本 工资 与 奖金 合并 成 一 个 属性 
C. 去 掉 职工 号 属性 D. 去 掉 应 发 工资 属性 
17. 将 关系 模式 XS( 学 号 ,姓名 ,专业 ) 规 范 成 XSA( 学 号 ,姓名 ,专业 码 ) 和 ZY( 专业 
码 ,专业 名 ) 两 个 关系 模式 ,主要 目的 是 (。 ”)。 





A. 消除 数据 元 余 B. 节省 存储 空间 
C. 消除 插入 异常 D. 消除 更 新 异常 
18. 依据 数据 库 罗 辑 设 计 的 结果 一 一 关系 模式 ,在 DBS 中 创建 表 ,其 实质 是 设计 DBS 
的 (  )。 
A. 内 模式 B. 模式 
C. 外 模式 D. 外 模式 /模式 映像 
三 、 多 选 题 
1. 数据 库 逻 辑 设计 的 主要 任务 是 (。”)。 
A. 通过 DBMS 创建 数据 库 B. 用 E-R 模型 描述 事物 
C. 用 范式 规范 化 关系 D. 定义 数据 语义 
E. 数据 编码 F. 管理 和 维护 数据 库 中 的 数据 
2. 数据 语义 的 主要 作用 有 (  ” )。 
A. 确定 字段 名 称 B. 确定 字段 数据 范围 
C. 确定 表 中 记录 个 数 D. 确定 主键 
E. 确定 主 属性 


3. 在 考试 数据 库 中 ,关系 模式 “考生 ( 考 号 ,姓名 ) "的 考 号 唯一 确定 考生 ;关系 模式 
“科目 (科目 号 ,科目 名 )” 的 科目 号 唯一 确定 科目 ;关系 模式 “成 绩 ( 考 号 ,科目 号 ,分 数 )” 
中 ,一 个 考生 可 以 选 考 多 科 。 在 该 数据 库 中 ,( ”中 ) 是 实体 型 ,( ”四 ) 是 实体 属性 ， 
( 图 ) 是 主键 ,( ”@ ) 是 成 绩 模式 的 外 键 ,(”@@”) 是 成 绩 模 式 的 主 属性 。 
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A. 考生 B. 考 号 C. 姓名 D. 科目 
E. 科目 号 F. 科目 名 G. 成 绩 H. 分 数 
I ( 考 号 ,科目 号 ) 

4. 关于 数据 表 , 正 确 的 叙述 是 ( Ws 


A. 表 中 至 少 包 含 一 个 字段 B. 表 中 至 少 包含 一 个 记录 
C. 表 中 字段 可 以 重 名 D. 表 中 记录 可 以 重复 
E. 表 中 必须 有 主键 F. 表 中 必须 有 外 刍 
5. 表 中 主 关键 字 的 作用 是 (。” )。 
A. 控制 字段 名 唯一 性 B. 控制 记录 唯一 性 
C. 控制 表 中 字段 顺序 D. 控制 表 中 记录 的 顺序 
E. 控制 主 属性 非 空 F. 控制 表 非 空 
6. 关于 候选 码 .主键 .外 键 和 主 属性 ,正确 的 叙述 是 ( ” )。 
A. 外 键 是 所 在 表 的 主键 B. 外 键 是 关联 表 的 主键 
C. 外 键 是 所 在 表 的 主 属 性 D. 主 属性 是 候选 码 中 的 属性 
E. 主 属性 是 主键 中 的 属性 F. 主 属性 不 能 空 
7. 数据 表 是 无 重复 数据 记录 的 二 维 表 , 意 味 着 ( )。 
A. 数据 表 中 不 允许 套 表 B. 数据 表 必 须 有 外 键 
C. 数据 表 必 须 有 主键 D. 每 个 单元 格 最 多 存储 一 个 值 
E. 主 属性 的 值 可 以 空 F. 数据 库 中 必须 含 两 个 及 更 多 表 
8. 关于 数据 表 和 二 维 表 ,( ) 正确 。 
A. 二 维 表 均 可 作为 数据 表 B. 数据 表 都 是 二 维 表 


C. 一 个 二 维 表 可 分 解 成 多 个 数据 表 D. 数据 表 是 无 元 余 的 二 维 表 
E. 数据 表 可 没有 关键 字 
F. 数据 表 的 某 列 中 可 以 包含 不 同类 型 的 数据 
9. 在 关系 模式 MZ( 民族 码 ,民族 名 ,人 数 ) 中 ,民族 码 和 民族 名 均 无 重复 值 , ( ) 


可 以 作为 关键 字 。 
A. 民族 码 B. 民族 名 
C. 人 数 D. (民族 码 ,民族 名 ) 
E. (民族 码 , 人 数 ) F. (民族 名 ,人 数 ) 
10. 下 列 叙 述 中 ,正确 的 有 ( Ji 
A. 一 个 表 只 能 有 一 个 主 属性 B. 一 个 表 只 能 有 一 个 关键 字 
C. 一 个 表 只 能 有 一 个 主 关键 字 D. 关键 字 与 主 属性 一 一 对 应 
E. 一 个 表 可 能 含 多 个 主 属性 F. 只 有 主 关键 字 中 的 属性 是 主 属性 
11. 在 关系 模式 GP( 股 东 代码 ,股东 名 ,股票 代码 , 持 有 数量 , 均 价 ) 中 ,允许 股东 重 
名 ,一 个 股东 可 能 持 有 多 种 股票 ,( ) 是 主 属性 。 
A. 股东 代码 B. 姓名 
C. 股票 代码 D. (股东 代码 ,姓名 ) 
E. (姓名 ,股票 代码 ) 
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12. 对 范式 级 别 较 低 的 数据 表 进 行 操作 时 ,可 能 出 现 数据 操作 异常 。 这 里 的 操作 异 


常 主要 指 ( js 
A. 查询 异常 B. 更 新 异常 C. 插入 异常 D. 导出 异常 
E. 删除 异常 
13. 对 关系 模式 XS( 学 号 ,姓名 ,专业 名 ) 进行 操作 时 ,可 能 发 生 ( ) 操 作 异 常 。 
A. 插入 记录 B. 删除 记录 C. 查询 统计 D. 更 新 数据 


E. 修改 表 结构 
14. 规范 化 关系 模式 的 主要 目的 是 ( js 
A. 减少 关系 模式 个 数 B. 降低 数据 元 余 
C. 减少 表 的 连接 次 数 D. 减少 数据 操作 异常 
E. 减少 表 中 记录 个 数 
15. 在 表 2-2 中 ,(， 四) 完全 函数 依赖 于 ( 身份 证 号 ,岗位 编号 ) ,( ”加 ) 部 分 函 
数 依赖 于 (身份 证 号 ,岗位 编号 ) 。 
A. 姓名 B. 最 后 学 历 C. 所 学 专业 D. QQ 账号 
E. 笔试 成 绩 F. 面试 成 绩 G. 总 分 
16. 在 关系 模式 GP( 身份 证 号 ,姓名 ,股票 代码 , 持 有 数量 ) 中 ,允许 股东 重 名 ,一 个 股 
东 可 以 持 有 多 种 股票 ,( ) 成 立 。 





A. 身份 证 号 一 姓名 B. (姓名 ,股票 代码 ) 一 持 有 数量 
C. 股票 代码 一 持 有 数量 D. (身份 证 号 ,股票 代码 ) 一 持 有 数量 
E. 身份 证 号 一 股票 代码 F. (身份 证 号 ,股票 代码 ) 一 姓名 


17. 在 关系 模式 GP( 身份 证 号 ,姓名 ,股票 代码 , 持 有 数量 ) 中 ,允许 股东 重 名 ,一 个 股 
东 可 持 有 多 种 股票 ,(。 ”) 成 立 。 


A. (身份 证 号 ,股票 代码 ) 一 ,姓名 B. (身份 证 号 ,股票 代码 ) 一 姓名 
C. (身份 证 号 ,股票 代码 )- 持 有 数量 ”D，( 身 份 证 号 ,股票 代码 )- 持 有 数量 





E. 身份 证 号 心 姓名 F. (姓名 ,股票 代码 ) 一 身份 证 号 
18. 在 表 2-1 中 ,( 中 ) 完 全 函数 依赖 于 岗位 编号 ,(”@@ ) 传 递 函 数 依赖 于 岗位 
编号 。 
A. 岗位 名 称 B. 最 低 学 历 C. 聘任 要 求 D. 公司 名 称 
E. 公司 地 址 F. 邮政 编码 


19. 在 某 个 关系 模式 中 ,如 果 每 个 非 主 属性 都 完全 函数 依赖 于 关键 字 , 并 且 不 存在 传 
递 函数 依赖 关系 , 则 该 关系 模式 一 定 属于 ( ) 。 
A. 第 一 范式 B. 第 二 范式 C. 第 三 范式 D. BCNF 


E. 第 四 范式 
20. 在 普通 表格 规范 化 成 数据 表 的 过 程 中 ,应 该 进行 ( 。 “”) 工 作 。 
A. 二 维 表 合 并 成 多 维 表 B. 多 维 表 分 解 成 二 维 表 
C. 确定 主 关键 字 D. 分 割 属性 使 其 具有 原子 性 


E. 输入 数据 记录 使 其 非 空 
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21. 对 第 一 范式 的 关系 模式 要 求 条 件 是 ( ) 。 
A. 二 维 表 B. 有 外 键 C. 有 主键 D. 属性 原子 性 
E. 主 属性 非 空 F. 表 非 空 
22. 关系 模式 从 第 一 范式 规范 化 到 第 三 范式 ,需要 消除 (。” )。 
A. 主 属性 对 关键 字 的 部 分 函数 依赖 
B. 非 主 属性 对 关键 字 的 部 分 函数 依赖 
C. 主 属性 对 关键 字 的 传递 函数 依赖 
D. 非 主 属性 对 关键 字 的 传递 函数 依赖 
E. 属性 之 间 的 函数 依赖 
23. 在 第 三 范式 的 关系 模式 中 ,一 定 不 存在 ( )。 





A. 主 属性 部 分 函数 依赖 于 关键 字 B. 非 主 属性 部 分 函数 依赖 于 关键 字 
C. 主 属性 传递 函数 依赖 于 关键 字 D. 非 主 属性 传递 函数 依赖 于 关键 字 
E. 主 属性 完全 函数 依赖 于 关键 字 F. 非 主 属性 完全 函数 依赖 于 关键 字 


24. 一 个 学 生 只 能 属于 一 个 专业 ,可 以 选 考 多 门 课程 。 下 列 关 系 模式 中 ( ”四 ) 是 
第 一 范式 ,( 四， ) 是 第 二 范式 ,(，@@ ) 是 第 三 范式 。 由 (”@@”) 构 成 学 生 考试 数据 
库 模 式 比较 理想 。 

A. 学 生 (学 号 ,姓名 ,专业 代码 ,专业 名 称 ) 
B. 课程 (课程 码 ,课程 名 称 ,学 分 ) 

C. 成 绩 (学 号 ,课程 码 ,成 绩 ) 

D. 专业 (专业 代码 ,专业 名 称 ) 

E. 学 生 (学 号 ,姓名 ,专业 代码 ) 

F. 成 绩 (学 号 ,课程 码 ,课程 名 称 ,学 分 ,成 绩 ) 

25. 对 数据 进行 编码 的 主要 作用 有 ( ” )。 








A. 易于 信息 标准 化 B. 降低 数据 宛 余 度 
减少 数据 操作 异常 D. 充分 利用 数据 采集 技术 
E. 、 池 省 数据 存储 空间 F. 提高 数据 处 理 \ 传 输 速 度 


26. 在 DBS 的 三 层 模式 结构 中 ,通常 ( ”QW ”) 涉 及 内 模式 ,(”@@ ) 涉 及 模式 ， 
( 图 ) 构 建 或 使 用 外 模式 。 
A. DBMS 研发 人 员  B. DBMS C. 数据 库 设计 员 。 D. 应 用 程序 
E. 普通 用 户 F. 数据 库 管 理 员 


、 数据库 设计 题 

1. 在 表 2-15 中 ,每 人 每 月 发 放 一 次 工资 。 职 称 分 正高 . 副 高 .中 级 和 初级 4 级 ,每 月 
都 要 保存 所 得 税 和 社会 保险 数据 ;合计 = 职务 工资 + 岗位 津贴 + 奖金 , 实 发 工资 = 合计 - 
所 得 税 -社会 保险 。 根 据 表 2-15 ,设计 符合 第 三 范式 要 求 的 职工 工资 数据 库 。 

2. 在 表 2-16 中 ,每 人 可 能 有 多 个 股东 账号 ,每 个 股东 账号 可 以 有 多 只 股票 ,但 仅 在 
第 一 只 股票 记录 上 记载 资金 余额 。 根 据 表 2-16 ,请 设计 符合 第 三 范式 要 求 的 股东 信息 数 
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据 库 。 


表 2-15 ”职工 信息 表 




































































应 发 工资 扣 款 实 发 
月 份 | 职工 号 | 姓名 工作 时 间 | 职称 | 性 别 | 职务 | 岗位 | 所 得 | 社会 | 工资 
工资 | 津贴 税 | 保险 
0701 | 000101 | 李 晓 伟 | 1982/07/01 | 正高 | 男 | 1370 | 1200 | 1650 | 4220 | 253 | 300 | 3667 
0701 | 100219 | 王 春 丽 | 1986/07/01 | 副 高 | 女 | 925 | 800 | 1350 | 3075 | 102 | 245 | 2728 
0701 | 400309 | 马 霄 汉 | 1999/07/01 | 中 级 | 男 | 710 | 500 | 900 |2110 | 25 | 50 | 2035 
0701 | 601012 | 赵 雪 丹 | 2004/01/01 | 初级 | 女 | 600 | 350 | 700 | 1650 2 | 30 | 1618 
表 2-16 股东 信息 表 

i a. 资金 | 股票 持 有 

号 + 时 间 账号 电话 票 名 称 9 价 | 现 
身份 证 号 | 姓名 | 开户 时 间 | 股东 账号 | 联系 电话 余额 | 代码 股票 名 称 数量 均 价 | 现价 
a 王晓光 12002/07/01| A01010321 | 85666453 | 20010| 600000 | 浦发 银行 | 700| 10.21 |11.50 
机 王晓光 |2002/07/01| A01010321 | 85666453 600008 | 首创 股份 | 15000| 5.43 | 7.22 
8801011965 
王晓光 |2002/07/01| B06120323 | 85666453 | 40000| 600019 | 宝钢 股份 | 13200| 7.25 | 6.01 
ee 赵 雪 丹 |2004/01/01| A09010201 | 13843037563 | 150000| 600003 | 东北 高 速 | 500| 5.62 | 4.98 



































3. 表 2-17 是 登记 学 生 考 试 信息 的 表格 。 学 号 唯一 标识 学 生 ;一 个 学 生 可 以 选 多 门 课 
程 ,对 任何 一 门 课程 只 能 选 一 次 ,考试 没 通过 者 可 以 重修 ;总 分 = 考试 成 绩 + 课堂 成 绩 + 实 
验 成 绩 。 根 据 实体 型 一 表 化 的 设计 原则 ,将 表 2-17 规划 成 满足 第 三 范式 要 求 的 学 生 考试 











数据 库 。 
表 2-17 学 生 考 试 信息 登记 表 
成 ” 绩 学 | 重 
[4 中 族 i 本 
学 号 | 姓名 | 性 别 | 出 生日 期 | 民族 课 程 考试 | 课堂 | 实验 | 总 | 分 | 修 
大 学 计算 机 基础 65 9 | 10 |8414 
- | 英语 56 19 85 | 5 
22060101 | 马 伟 立 | 男 | 1987/10/12 | 汉族 高 等 数学 C 5 | : 褒 58 4 vy 
大 学 计算 机 基础 50 3 7 | 人 6 |14 
11050102 | 赵 晓 敏 | 女 | 1988/05/01 | 朝鲜 族 | 英语 55 6 61 |5 |V 
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9 学 | 重 
学 号 | 姓名 | 性 别 | 出 生日 期 | 民族 课 程 考试 | 课堂 | 实验 | 总 | 分 | 修 
成 绩 | 成 绩 | 成 绩 | 分 
大 学 计算 机 基 75 | 10 | 10 |95 |4 
高 等 数学 B 79 | 20 99 | 4 


12060201 | 孙武 | 男 | 1989/03/02 | 满族 数据 库 及 程序 设计 | 50 5 7 |6 14 






































1. 数据 表 是 二 维 表 , 是 否 所 有 二 维 表 都 可 以 作为 数据 表 ? 为 什么 ? 

2， 如 果 一 个 关系 模式 中 不 存在 传递 函数 依赖 关系 ,那么 此 关系 模式 是 否 一 定 属于 第 
三 范式 ? 

3， 在 关系 模式 CWCJB( 身份 证 号 ,岗位 编号 ,资格 审核 ,笔试 成 绩 ,面试 成 绩 ) 中 ( 如 
表 2-7 所 示 ) ,显然 有 “(身份 证 号 ,岗位 编号 ) 一 ,身份 证 号 "和 “(身份 证 号 ,岗位 编号 ) 一 
岗位 编号 ” ,能 否 由 此 判定 GWCJB 不 是 第 二 范式 的 关系 模式 ? 为 什么 ? 

4. 在 YPRYB( 身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 ,最 后 学 位 ,所 学 专业 ,通信 地 址 ,邮政 
编码 ,Email 账号 ,QQ 账号 ,固定 电话 ,移动 电话 ,密码 ,个 人 简历 ) 关系 模式 中 , 除 最 后 学 
历 和 最 后 学 位 外 ,还 可 以 对 哪些 属性 进行 编码 ”通过 数据 编码 能 消除 一 些 宛 余数 据 吗 ? 


为 什么 ? 
5. 在 关系 模式 规范 化 过 程 中 ,必须 保证 关系 模式 无 损 性 分 解 。 这 里 “无 损 "的 含义 是 
什么 ? 


6. 在 数据 库 系统 的 三 层 模式 中 ,哪些 模式 存储 在 客户 端 或 服务 器 ? 
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MySQL 数据 库 管 理 与 维护 


数据 库 迎 辑 设计 的 成 果 一 一 关系 模式 , 仅 是 一 种 理论 模型 ,也 是 创建 物理 数据 库 的 理 
论 基础 和 依据 。 要 使 关系 模式 付 诸 实 施 , 能 投入 实际 应 用 ,还 需要 借助 一 种 数据 库 管理 系 
统 (DBMS) 在 计算 机 上 进行 创建 ,管理 和 维护 一 一 物理 设计 数据 库 。 

MySQL 是 一 种 目前 比较 实用 的 、 基 于 互联 网 的 关系 (数据 表 , 简 称 表 ) 型 数据 库 管 理 
系统 。 系 统管 理 员 和 互联 网 应 用 程序 开发 人 员 ( 也 称 用 户 ) 经 常 要 用 某 些 数据 库 管 理 平 
台 ( 如 PHPMyAdmin .Navicat 和 命令 窗口 等 ) 直接 访问 数据 库 , 互 联网 客户 往往 通过 浏览 
器 调用 PHP 程序 间接 地 访问 数据 库 。 

要 使 一 个 网 站 能 持续 有 效 地 运转 ,吸引 更 多 的 客户 ,必须 保障 数据 库 及 时 更 新 和 维 
护 , 因 此 ,数据 库 管理 与 维护 是 网 站 高 效 平稳 运行 中 的 重要 环节 。 在 建设 管理 和 维护 数 
据 库 的 过 程 中 ,有 必要 弄 清 下 列 问题 : 

(1) 如 何 使 用 数据 库 管 理 与 维护 平台 (软件 系统 ) 物理 设计 数据 库 ? 相关 平台 有 哪 
些 功 能 及 工具 ? 

(2) 如 何 管理 用 户 及 其 操作 权限 ?怎样 划分 用 户 的 权限 ? 

(3) 如 何 创建 维护 数据 库 及 其 数据 表 , 关 键 字 对 数据 表 的 作用 是 什么 ? 

(4) 如 何 操纵 (输入 ,修改 和 删除 ) 和 查看 数据 库 中 的 数据 ? 

(5) 为 了 数据 库 备份 或 移植 到 其 他 服务 器 上 ,如 何 导入 或 导出 数据 库 ? 





3.1 MySQL 数据 库 的 常用 管理 工具 


在 MySQL 数据 库 管理 系统 中 ,可 以 执行 语句 或 可 视 化 操作 (选项 卡 、 对 话 框 和 按钮 
等 ) 来 进行 数据 库 管理 和 维护 。 目 前 , MySQL 数据 库 的 可 视 化 管理 软件 很 多 ， 
PHPMyAdmin 是 其 中 比较 常用 的 一 种 。 


3.1.1 MySQL 命令 窗口 


在 XAMPP 的 控制 台 上 (如 图 1-12 所 示 ) ,启动 MySQL 服务 后 , 单 击 Shell 按钮 ,进入 
MySQL 命令 窗口 (初始 提示 符 为 井 号 “#” ) 。 


以 纯 代 码 方式 操作 MySQL 命令 窗口 , 即 ,一 切 操作 均 需 要 输入 和 执行 MySQL 命令 或 
SQL( Structured Query Language ,结构 化 查询 语言 ) 语 句 (统称 MySQL 语句 ) 来 完成 。 


1. 登录 数据 库 服 务 器 


执行 数据 库 管理 与 维护 操作 (或 MySQL 语句 ) 之 前 ,应 该 在 命令 提示 符 *#" 下 执行 下 
列 语句 ,以 便 连 接 并 登录 数据 库 服务 器 。 

语句 格式 : 

MySQL， [ua< 用 户 名 习 [ 二 笋 据 库 服务 器 了 地 址 习 [了 [< 密码 习 ] 

其 中 uh 和 p 必须 是 小 写字 母 ,相关 选项 的 含义 如 下 : 

(1) -u< 用 户 名 > : 系统 对 登录 用 户 名 中 的 英文 字母 区 分 大 小 写 , 如 Root 与 root、 
YPRY 与 ypry 均 是 不 同 的 用 户 , 因 此 ,创建 与 登录 时 用 户 名 必须 一 致 。 

MySQL 系统 (或 XAMPP) 成 功 安装 后 ,初始 用 户 名 为 超级 管理 员 root, 没 有 密码 ,具有 
所 有 全 局 权限 。 执 行 登录 数据 库 服 务 器 语句 时 ,如 果 省 略 用 户 名 , 则 系统 以 root 身份 
登录 。 

(2) -h < 数据 库 服 务 器 IP 地 址 > : 省 略 此 项 时 ,系统 默认 地 址 是 127. 0. 0. 1 ,表示 本 
地 数据 库 服务 器 。 登 录 到 其 他 数据 库 服 务 器 时 ,要 写真 实 的 服务 器 地 址 ,如 -h202. 198. 
2 

(3) -p[ < 密码 > ] : 登录 的 用 户 无 密码 时 ,可 省 略 此 项 。 如 果 只 写 p 而 不 写 密码 , 按 
Enter 键 后 ,系统 将 要 求 输入 密码 (Enter Password) ,并 以 占 位 符 “ * ”显示 输入 的 密码 。 

【 例 3.1】 以 用 户 gly 的 身份 (密码 为 gly985 ) 登录 到 IP 地 址 为 202. 198. 122. 1 的 数 
据 库 服务 器 。 


MySQL -ugly -h202.198.122.1 -pgly985 
语句 中 的 每 个 选项 由 半角 减 号 *-" 开 始 , 减 号 前 至 少 一 个 空格 。 登 录 数 据 库 服务 带 
成 功 后 ,进入 MySQL 命令 方式 ,在 提示 符 “mysql- > "下 ,可 以 输入 和 执行 MySQL 语句 。 
【 例 3.2】 以 用 户 root 身份 登录 本 地 数据 库 服务 器 。 
MySQL -uroot 


由 于 以 用 户 root 身份 (初始 无 密码 ) 登录 本 地 数据 库 服务 器 ,因此 ,语句 中 省 略 了 数 
据 库 服务 器 IP 地 址 及 用 户 密码 。 登 录 过 程 及 MySQL 命令 窗口 如 图 3-1 所 示 。 


2. 输入 和 执行 MySQL 语句 


在 MySQL 命令 窗口 的 提示 符 “mysql- > "下 ,输入 MySQL 语句 时 , 按 Enter 键 另 起 一 
行 , 继 续 输 入 当前 语句 的 剩余 部 分 ; 按 半角 分 号 “ ; "并 按 Enter 键 开 始 执行 语句 ; 按 光标 方 
向 控制 键 1 、4 < 或 一 可 以 改变 光标 位 置 ,也 可 以 找 回执 行 过 的 语句 ,再 次 修改 后 按 
Enter 键 重新 执行 。 

MySQL 命令 窗口 可 以 与 Windows 中 其 他 软件 (如 记事 本 和 了 PHPMyAdmin 等 ) 通 过 “ 复 
制 " 和 ”粘贴 ” 的 办 法 ,进行 信息 (语句 ,短语 ,字段 名 及 处 理 结果 等 ) 交换 。 
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控制 菜单 - 二 XANPP for Windows 一 NySQL -uroot 


lsetting environnent for using XAMPP for Windows. 





登录 数据 库 dase ote A e791 e:\nysql_du\xanpp 
各 归于 MySQL —uroor 
服务 器 语句 end with ; or \g- 


登录 成 功 后 


显示 的 信息 


”or ’\h’ for help. Type ’\e’ 
MySQL 语 句 
er ywyBLocalhos 
a By ’ yuy211’ 
lQuery OK. @ rows affected 《8.B8 sec) 


nysal> 








图 3-1 MySQL 命令 窗口 


(1) 将 MySQL 命令 窗口 的 内 容 送 入 剪贴 板 : 单 击 MySQL 命令 窗口 的 控制 菜单 一 
“编辑 "一 “标记 ”选项 ,在 窗口 中 拖 动 鼠标 选 定 相关 内 容 ,再 单 击 控制 菜单 一 “编辑 ”一 
“复制 "选项 。 利 用 这 种 方法 ,也 可 以 将 语句 及 其 输出 结果 送 入 剪贴 板 , 以 便 粘贴 到 其 他 
软件 (如 Word .Excel 等 ) 中 进行 进一步 数据 处 理 

(2) 将 剪贴 板 中 的 内 容 粘贴 到 MySQL 命令 行 : 单 击 MySQL 命令 窗口 的 控制 菜 
单一 "编辑 "一 “粘贴 "选项 ,可 以 将 系统 剪贴 板 中 的 内 容 粘贴 到 光标 当前 位 置 

特别 是 当 语 句 中 含有 汉字 时 ,不 便 在 MySQL 命令 窗口 中 输入 ,借助 记事 本 或 
PHPMyAdmin 软件 先进 行 输入 ,然后 再 复制 ,粘贴 到 语句 行 光标 位 置 ,使 操作 更 方便 灵活 ， 


3. 关闭 MySQL 命令 窗口 


在 单 击 MySQL 命令 窗口 的 “关闭 "按钮 或 控制 菜单 的 “关闭 "选项 之 前 ,应 该 在 命令 
行 执行 Quit 或 Exit 语句 , 断 开 与 数据 库 服务 器 的 连接 





3.1.2 PHPMyAdmin 可 视 化 窗口 


对 于 不 习惯 MySQL 命令 窗口 操作 的 用 户 , 可 以 通过 PHPMyAdmin 可 视 化 窗口 编辑 、 
生成 和 运行 MySQL 语句 。PHPMyAdmin 可 视 化 窗口 比 MySQL 命令 窗口 方式 更 适合 初 
学 者 ， 

PHPMyAdmin 可 视 化 窗口 采用 混合 式 操作 模式 , 既 可 以 通过 键盘 或 鼠标 操作 选项 、 对 
话 框 和 按钮 等 对 象 ,也 可 以 输入 和 执行 MySQL 语句 。 对 某 些 简单 任务 要 求 ,通过 键盘 和 
鼠标 的 基本 操作 ,而 不 需要 键盘 输入 MySQL 语句 , 即 可 完成 任务 。 





1. PHPMyAdmin 主页 


在 XAMPP 的 控制 台 (如 图 1-12 所 示 ) ,启动 MySQL 服务 后 , 单 击 MySQL 行 的 Admin 
按钮 ,进入 PHPMyAdmin 登录 窗口 ,输入 用 户 名 和 密码 后 , 单 击 “ 执 行 " 按 钮 ,登录 数据 库 
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服务 器 并 进入 PHPMyAdmin 主页 ,如 图 3-2 所 示 。 
































































快捷 工具 按钮 ”数据 库 窗 格 功能 选项 卡 系统 状态 及 操作 区 
到 6 数据 库 局 SQL | 加 状态 上 用户 尼 导 出 因 导 A v 更 多 本 
常规 设置 数据 库 服 务 器 
全 修改 密码 e 服务 器 127.0.0.1via 
“ 恒 服 务 器 连接 校对 名 TCRPIP 
( 佑 这 合用 的 表 ) /” 国 I a 
国 cdcol 。 软件 版 本 : 5.5.27 - MySQU| 
Community Server (GPL) | 旺 
国 information_schema py 。 协议 版 本 : 10 
外 观 设 置 e 用 户 ; root@localhost 
司 mysql e 服务 器 字符 集 ; UTF-8 
本 Language © : Unicode (utfe) 
回 performance_schema 中 文 - Chinese simplfied 四 
”| 时 主 题 [pmahomme 国 
国 phpmyadmin 。 宁 号 [2% 国 网 站 服务 器 
@ test 访 更 多 设置 ® Apache/2.4.3 (Win32) 
E] OnPnSsSl1nir 加 | 











a | 本 | ”本 三 生 | [] 








图 3-2 PHPMyAdmin 主页 


PHPMyAdmin 可 视 化 窗口 中 的 各 部 分 内 容 及 作用 如 下 : 

(1) 快捷 工具 按钮 。 是 进入 查询 窗口 (SQL 选项 卡 ) .刷新 和 返回 主页 等 常用 按钮 。 

(2) 功能 选项 卡 。 项目 及 个 数 不 仅 与 当前 登录 用 户 的 权限 有 关 , 也 与 当前 对 象 ( 如 
数据 库 或 数据 表 ) 窗口 有 关 。 单 击 某 个 选项 卡 , 进 入 对 应 的 窗口 ,可 以 实现 各 种 对 象 的 相 
关 操 作 。 常 用 选项 卡 有 : 

。 数据 库 : 用 于 创建 .删除 MySQL 数据 库 ,检查 数据 库 权限 等 。 

。 SQL: 用 于 输入 执行 MySQL 语句 。 

。 用 户 : 用 于 添加 、 修 改 和 删除 用 户 ,为 用 户 授权 等 。 

。 更 多 : 当前 窗口 较 窗 ,用 一 行 不 能 显示 全 部 选项 卡 时 ,系统 将 未 尾 的 一 些 选 项 卡 

汇集 到 “更 多 ”选项 卡 中 。 单 击 该 选项 卡 ,将 弹出 这 些 选项 卡 列表 ,如 字符 集 ( 整 
理 或 编码 ) 的 详细 说 明 ,数据 的 “导入 "和 “导出 "等 。 

(3) 数据 库 窗 格 。 用 于 显示 当前 服务 器 中 的 MySQL 全 部 数据 库 名 。 单 击 某 个 数据 
库 名 (如 MySQL 、Test 等 ) 即 可 将 其 设 为 当前 数据 库 , 同 时 打开 当前 数据 库 的 信息 窗口 ,可 
以 进一步 对 当前 数据 库 及 其 数据 表 进 行 操作 。 

(4) 系统 状态 及 操作 区 。 用 于 显示 系统 的 当前 状态 .操作 结果 ,也 可 以 进行 某 些 操 
作 , 例 如 ,选择 “服务 器 连接 校对 ”, 设 置 数据 库 默 认 的 字符 集 规则 等 。 


2. 输入 和 执行 MySQL 语句 


单 击 PHPMyAdmin 主页 的 SQL 选项 卡 ,进入 MySQL 语句 输入 及 执行 窗口 ,如 
图 3-3 所 示 。 

在 MySQL 语句 编辑 框 中 ,输入 MySQL 语句 (如 Create User …) 后 , 单 击 “ 执 行 "按钮 ， 
便 完成 语句 的 功能 ,例如 ,创建 用 户 ywy。 
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局 数据 库 辐 SOL 加 状态 za 用 户 局 导出 v 更 多 





在 服务 品 “127.0.0.1" 运行 SQL 查询 : 全 


1 Create User ywy@LocalHost 

| |2 Identified By 'ywy211' /* 创建 主机 用 户 
MySQL 语 句 | 名 为 ywy， 密 码 为 ywy211 */ 
编辑 框 


























将 此 SQL 查询 加 为 书 答 
[证 办 竺 |。 | 。 | ] 在 此 再 次 旺 示 此 查询 口 保 和 查询 模 [了 和] 
| 
MySQL 语 句 的 开始 "执行 ” 
结束 符号 *;” 语句 的 按钮 


图 3-3 ”MySQL 语句 输入 及 执行 窗口 


3.2 ”MySQL 语句 的 语法 规则 


MySQL 作为 数据 库 管理 及 应 用 程序 的 开发 工具 ,用 户 可 以 对 其 进行 可 视 化 或 命令 
(语句 ) 操 作 , 以 此 完成 相关 的 任务 。MySQL 语句 作为 一 种 人 与 计算 机 进行 交流 的 语言 ， 
它 有 自身 的 语法 规则 和 设计 要 求 ,在 编辑 MySQL 语句 时 应 该 遵循 这 些 规则 。 


1. 半角 圆 点 的 作用 


半角 圆 点 “. "除了 作为 数值 型 数据 中 的 小 数 点 和 日 期 型 数据 中 的 年 月 日 之 间 的 分 隔 
符 外 ,还 用 作 数 据 库 名 与 数据 源 名 (数据 表 或 视图 ) ,数据 源 名 与 字段 名 之 间 的 分 隔 符 , 即 
用 “. "表示 隶属 关系 。 

【 例 3.3】 写 出 能 输出 申报 人 员 的 身份 证 号 、 姓 名、 岗位 名 称 和 笔试 成 绩 的 SQL 
语句 。 

select YPRYB. 身 份 证 号 ,姓名 ,岗位 名 称 ,笔试 成 绩 

From RCZP .YPRYB, RCZP .GWCJB, RCZP .GWB Where YPRYB. 身 份 证 号 =-GWCJB. 身 份 证 号 

znd GWCJB. 岗 位 编号 -GWB. 岗 位 编号 ; /* SQL 的 多 表 查 询 语句 * / 

本 例 中 RCZP. YPRYB 、RCZP. GWCJB 和 RCZP. GWB 表示 YPRYB .GWCJB 和 GWB 
均 为 数据 库 RCZP 中 的 数据 表 。 在 RCZP 是 当前 数据 库 的 情况 下 ,语句 中 的 “RCZP. "可 
以 省 略 。 

如 果 某 字段 名 出 现在 SQL 语句 两 个 或 更 多 数据 源 中 , 则 该 字段 名 前 面 的 数据 源 名 和 
圆 点 通常 不 能 省 略 。 例 如 ,本 例 SQL 语句 的 数据 源 是 YPRYB、GWCJB 和 GWB 三 个 数据 
表 , 其 中 YPRYB 和 GWCJB 中 都 含 身份 证 号 字段 ,GWCJB 和 GWB 中 均 有 岗位 编号 字段 ， 
因此 ,身份 证 号 和 岗位 编号 前 面 的 数据 表 名 和 圆 点 都 不 能 省 略 。 但 只 在 一 个 数据 源 中 出 
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现 的 字段 名 (如 姓名 ,岗位 名 称 和 笔试 成 绩 等 ) 都 可 以 省 略 数据 源 名 和 圆 点 。 
2. 引号 的 作用 


(1) 右 单 引 号 ”“”( 俗 称 单 引 号 ) 或 双 引 号 “"”: 字符 串 型 (如 Char VarChar 和 Text 
等 ) 或 日 期 时 间 型 (如 Date 和 DateTime 等 ) 常数 需要 用 单 引 号 或 双 引 号 引起 来 。 

(2) 左 单 引 号 “” : 是 与 ” ~ "同一 个 键 钮 的 下 档 符 号 。 包 含 标点 符号 和 运算 符 等 专 
用 符号 的 数据 库 ,数据 表 或 字段 名 必须 用 左 单 引 号 引起 来 ,表示 一 个 完整 的 名 称 ;对 于 
常规 符号 (如 汉字 .英文 字母 ) 组 成 的 数据 库 数据 表 或 字段 名 是 否 引 起 来 ,效果 不 受 
影响 。 

【 例 3.4】 设计 一 条 SQL 语句 ,输出 2017 年 1 月 15 日 进行 笔试 的 岗位 情况 ,包括 岗 
位 编号 和 岗位 名 称 。 

Select 'GWB' .' 岗 位 编号 ', 岗 位 名 称 From 'GWB' 

/* 左 单 引号 将 GmB、 岗 位 编号 分 别 引 起 来 , 左 单 引 号 可 省 略 * / 

Where 笔试 日 期 ='2017.1.15" /* 单 引号 将 日 期 型 常数 引起 来 * /; 

语句 中 的 日 期 型 常数 2017. 1. 15 用 单 引号 引起 来 ,字段 名 “岗位 编号 "和 数据 表 名 
GWB 都 分 别 用 左 单 引号 引 了 起 来 ,切记 不 能 写成 GWB. 岗位 编号 `, 而 字段 名 “岗位 名 称 ” 
和 ”笔试 日 期 "并 没有 引起 来 ,这 不 影响 语句 的 功能 。 


3. 英文 字母 的 大 小 写 


除 系统 保留 字 ( 系统 专用 词 ,如 Create .User、Select、As 、From、Where 及 And 等 ) 和 内 
葡 函 数 名 ( 如 Sum 和 Left 等 ) 必 须 是 英文 外 ,在 数据 库 和 数据 表 等 用 户 自 定义 的 名 称 中 也 
可 以 使 用 英文 字母 ,系统 对 这 些 英 文字 母 都 不 区 分 大 小 写 。 哪 些 字母 用 大 写 或 小 写 ,由 用 
户 个 人 习惯 而 定 。 为 便于 读者 阅读 ,本 书 按 英语 书写 惯例 ,英文 单词 首 字母 (或 缩写 词 ) 
用 大 写 ,其 余部 分 用 小 写 。 但 字符 串 型 数据 中 的 英文 字母 往往 有 大 小 写 之 分 。 

在 例题 3.3 的 SQL 语句 中 ,Select、RCZP 和 YPRYB 等 写成 SeleeT .Rezp 和 ypryb 等 大 
小 写 混合 形式 , 均 不 会 影响 语句 的 功能 。 


4. 空格 的 作用 


空格 是 语句 名 (语句 中 的 第 一 个 英语 单词 ,如 Create ,Select 和 Update 等 ) ,短语 名 ( 语 
句 中 的 其 他 保留 字 , 如 User、As From 和 Where 等 ) 和 逻辑 运算 符 ( 如 And .Or 和 Not 等 ) 
与 其 他 项 之 间 的 分 隔 符号 。 这 种 分 隔 至 少 用 一 个 空格 ,多 用 空格 不 影响 语句 的 功能 。 但 
是 ,有 些 运算 符 ( 如 +、- 、,* /、=、> 等 ) 左 右 不 需要 空格 。 

在 例题 3. 3 的 SQL 语句 中 ,Select 后 有 一 个 空格 ,From 、Where 和 And 左右 侧 均 有 
空格 。 


5. 半角 方式 符号 
语句 中 的 英文 字母 数字 (0 ~9) .运算 符号 (如 +、-、*V%&|、、~、=、<、> 
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和 1!) 、 各 种 标点 符号 ( 如 逗号 左 单 引号 、 单 引号 、 双 引号 、 圆 点 、 小 括号 和 空格 ) 一 律 以 半 
角 方式 输入 。 字 符 串 型 数据 中 的 符号 输入 方式 不 限 , 半 角 和 全 角 字 符 均 可 ,但 同一 个 字符 
(如 AX 和 5 等) 的 不 同 输入 方式 ,属于 两 个 不 同 字符 。 


6. 语句 分 行 


每 行 以 回 车 结束 ,如 图 3-1 和 图 3-3 中 的 语句 所 示 。 一 条 语句 可 以 编辑 成 多 行 ,但 语 
句 中 一 个 完整 项 (如 语句 名 ,短语 名 数据库 名 .数据 源 名 .字段 名 、 函 数 调用 和 一 个 数据 
等 ) 不 能 分 行 。 可 以 从 表达 式 的 运算 符 处 分 行 ,但 不 要 将 多 个 符号 构成 的 一 个 运算 符 
(如 ! =、<=、< > 和 < = > 等 ) 分 成 两 行 。 


7. 注释 信息 


注释 信息 是 为 人 们 方便 阅读 程序 或 语句 时 所 编写 的 信息 ,而 不 影响 程序 和 语句 的 执 
行 功能 。 在 编辑 MySQL 语句 时 ,注释 信息 用 */ * "和 ”**/" 括 起 来 ,可 以 写 在 语句 中 的 任 
何 位 置 。 例 如 ,图 3-1 和 图 3-3 中 都 有 注释 信息 ; 例 3.3 中 的 “/* SQL 的 多 表 查 询 语句 
*/” 和 例 3.4 中 的 “/* 左 单 引 号 …… 可 省 略 */" 也 是 注释 信息 ,在 输入 语句 时 ,可 以 
不 输入 这 些 信 息 。 

在 编辑 MySQL 语句 时 ,如 果 违 背 上 述 规则 , 则 执行 语句 时 系统 将 指出 错误 ,需要 修改 
正确 后 , 方 能 正常 执行 下 去 ,完成 语句 的 功能 。 





3.3 用 户 管理 


在 MySQL 数据 库 管理 系统 中 ,用 户 所 能 进行 的 操作 与 所 授予 的 权限 有 关 。 从 数据 保 
密 和 信息 安全 的 角度 考虑 ,安装 MySQL 系统 之 后 ,以 用 户 root 登录 到 数据 库 服 务 器 ,要 添 
加 新 用 户 ( 如 管理 员 gly .业务 员 ywy 和 应 聘 人 员 ypry 等 ) 并 授予 相应 的 权限 。 


3.3.1 添加 用 户 


1. 添加 用 户 的 操作 


通过 PHPMyAdmin 可 视 化 操作 添加 用 户 ,需要 登录 具有 Create User 和 Select 权限 的 
用 户 。 在 PHPMyAdmin 主页 上 , 单 击 “ 用 户 " 选 项 卡 一 “添加 用 户 " 按 钮 ,在 “登录 信息 ” 窗 
口中 输入 用 户 名 .主机 名 及 密码 等 ,如 图 3-4 所 示 , 最 后 再 单 击 “ 添 加 用 户 ” 按 钮 即 完 成 创 
建 用 户 的 操作 。 

(1) 用 户 名 : 可 以 包含 汉字 英文 字母 或 数字 ,其 中 英文 字母 要 区 分 大 小 写 , 因 此 , 登 
录 服 务 器 时 要 与 此 名 一 致 。 

(2) 主机 : 在 “主机 "下 拉 框 中 ,可 以 选择 “本 地 ”(LocalHost ,字母 不 区 分 大 小 写 ) , 表 
示 添 加 当前 服务 器 上 的 用 户 ; 选 择 “ 任 意 主 机 ” ( % ) 表示 添 加 连接 当前 服务 器 的 其 他 计算 
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| 二 用户 | 
用 户 各: [使 用 文本 域 ; 国 [ywy 日 
主机 : [ 末 地 图 |localhost © 
密码 ; [合用 文本 域 : | 
重新 输入 : eee 
出 生成 密码 ; [生成] 











添加 用 户 取消 








图 34 添加 用 户 窗口 


机 上 的 用 户 , 即 , 非 当 前 服务 器 上 的 用 户 。 其 他 计算 机 上 的 用 户 ,只 有 在 其 他 计算 机 上 登 
录 当 前 服务 器 才能 操作 数据 库 , 即 使 授予 一 些 权限 ,在 当前 服务 器 上 登录 ,也 不 会 有 任何 
操作 权限 。 

(3) 密码 : 在 其 下 拉 框 中 可 以 选择 “无 密码 ” ;选择 “使 用 文本 域 " 时 ,需要 为 用 户 设 
置 密码 ,其 中 英文 字母 也 区 分 大 小 写 。 


2. 添加 用 户 的 MySQL 语句 


对 执行 Create User 语句 的 用 户 ( 如 root) 要 求 有 Create User 权限 。 
语句 格式 : 
Create User < 用 户 名 1 >[@ 主 机 名 ] [Identified By < 密码 1 习 …… 
[， < 用户 名 n >[@ 主 机 名 ] [Identified By < 密码 n 习 
此 语句 执行 一 次 ,可 以 添加 多 个 用 户 。 语 句 中 的 各 项 含义 如 下 : 
(1) 主机 名 : 用 于 说 明 用 户 所 在 的 计算 机 ,通常 是 '% ' (任意 主机 ) 或 LocalHost( 当前 
服务 器 ) 之 一 , 若 省 略 “@ 主机 名 "选项 , 则 系统 默认 是 @ '% '。 
(2) Identified By < 密码 > : 用 于 指定 用 户 密 码 的 字符 串 ,省 略 此 项 表示 无 密码 。 
【 例 3.5】 添加 当前 服务 器 上 的 业务 员 用 户 ywy, 密 码 为 ywy211; 管 理 员 用 户 
gly ,密码 为 gly985。 其 他 计算 机 上 的 应 聘 人 员 用 户 ypry 和 临时 用 户 TM ,二 者 均 无 
密码 。 
Create User ywy@ LocalHost Identified By 'ywy211", 
gly@ LocalHost Identified By 'gly985", 
ypry@ '$',T™ /+ @'9' 可 以 省 略 * / 
密码 和 % 都 要 用 引号 引起 来 ,而 用 户 名 和 LocalHost 不 需要 。 执 行 此 语句 除 添加 了 图 
3 上 4 中 的 用 户 ywy 外 ,还 添加 了 当前 服务 器 上 的 gly 以 及 其 他 计算 机 上 的 两 个 用 户 ypry 和 
TM ,二 者 均 没有 设 密码 。 
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3.3.2 修改 用 户 信息 


修改 用 户 信息 是 指 修改 用 户 名 .主机 名 和 密码 等 。 
1. 修改 与 复制 用 户 信息 的 操作 


如 果 要 复制 用 户 权 限 ,要 求 登录 用 户 除 具 有 Create User 和 Select 权限 外 ,还 应 该 有 


Grant 权限 。 


在 PHPMyAdmin 主页 上 , 单 击 “ 用 户 " 选 项 卡 , 在 “用 户 概况 ”信息 表 中 (如 图 3-5 所 
示 ) ,可 以 查看 用 户 名 及 全 局 权限 , 单 击 用 户 ( 如 ywy 或 ypry) 行 的 “编辑 权限 "按钮 可 以 修 


改 用 户 信息 及 其 权限 。 












































a 引 数据 库 司 SQL 怕 状 态 号 用 户 屋 导 出 v 更 多 
用 户 概况 
用 户 主机 。 密码 全 局 权限 名 授权 操作 
任意 % 赤 USAGE 否 ” 居 编辑 权限 图 导出 
任意 linux 否 USAGE 否 ”多 编辑 权限 吕 导出 
任意 localhost 否 UsAGE 否 居 编辑 权限 图 导出 
TM % 否 UsAGE 否 ”多 编辑 权限 电导 出 
gy localhost 是 usaGE 否 用 编辑 权限 加 导出 
选择 用 户 列 一 一 pma localhost 否 usAGE 否 ”多 编辑 权限 | 马 导出 
root linux 否 ALL PRIVILEGES 是 旋 编辑 权限 图 导出 
root localhost 否 ALL PRIVILEGES 是 局 编辑 权限 吕 导出 
ypry % 否 USAGE 否 旋 编辑 权限 图 导出 
ywy localhost 是 usAGE 否 名 编辑 权限 | 对 导出 
全 选 /全 不 选 
仿 添加 用 户 
[一 | 尽 删 除 选中 的 用 户 | 
(报销 用 户 所 有 权限 ， 然 后 删除 用 户 。) 
| _ 口 删除 与 用 户 同名 的 数据 库 。 
区 各 








图 3-5 “用 户 概况 "信息 框 














在 “修改 登录 信息 /复制 用 户 " 信息 框 中 (如 图 3-6 所 示 ) ,修改 用 户 名 .主机 名 和 密 


码 ,选择 相关 选项 ,最 后 单 击 对 应 的 “执行 "按钮 。 
常用 相关 选项 的 作用 如 下 : 


(1) 保留 旧 用 户 : 依据 旧 用 户 信息 (如 主机 名 、 用 户 名 或 权限 ) 修 改 主机 名 ( LocalHost 
或 % ) 和 用 户 名 后 ,添加 新 用 户 ,同时 保留 原 用 户 信息 。 通 常用 此 操作 复制 新 用 户 或 修改 


旧 用 户 的 密码 。 


(2) 从 用 户 表 中 删除 旧 用 户 : 依据 旧 用 户 信息 修改 主机 或 用 户 名 ,使 之 成 为 新 用 户 ， 


第 3 章 ，MysaQL 数据 库 管理 与 维护 “ (69) 








| 一 修改 登录 信息 /复制 用 户 | 


登录 信息 | 
用 户 各: [使 用 文本 域 : 国 ypry 


主机 : | 任意 主机 国 册 "% 
































密码 : | 保持 原 密 码 图 
重新 输入 ; 
生成 密码 : 生成 ] 






































[创建 具有 相同 权限 的 新 用 户 然后 … 
相关 选项 一 上 一 久保 留 旧 用 户 。 
ep 
ES 
| 9 
| 





从 用 户 表 中 删除 旧 用 户 。 
撤销 旧 用 户 的 所 有 权限 ， 然 后 删除 旧 用 户 。 
从 用 户 表 中 删除 旧 用 户 ， 然 后 重新 载 入 权限 。 

















图 3-6 “修改 登录 信息 /复制 用 户 "信息 框 
同时 删除 原 用 户 。 通 常 选中 此 项 实现 用 户 更 名 或 更 换 主机 。 
2. 修改 用 户 信息 的 MySQL 语句 


要 求 执行 Rename User 语句 的 用 户 有 Create User 权限 。 
语句 格式 : 


Rename User < 提 用 户 名 1 >[@ 旧 主机 名 1] To < 新 用 户 名 1 >[@ 新 主机 名 1],…… 
[, < 日 用 户 名 n >[@ 旧 主机 名 n] To < 新 用 户 名 n >[@ 新 主机 名 n]] 


该 语句 主要 用 于 更 改 用 户 名 称 和 主机 名 称 。 
【 例 3.6】 将 其 他 计算 机 上 的 用 户 TM 改 为 当前 服务 器 上 的 用 户 。 


Rename User TM@ '%' To TMQ LocalHost; 


执行 此 语句 后 ,用 户 TM 的 主机 由 其 他 计算 机 换 为 当前 服务 器 。 如 果 执 行 此 语句 前 
已 经 授予 用 户 TM 某 些 权限 , 则 更 换 主机 后 将 继承 这 些 权 限 。 


3.3.3 ”删除 用 户 


1. 删除 用 户 的 操作 

要 进行 删除 用 户 的 操作 , 登录 用 户 必须 有 Create User 和 Select 权限 。 在 
PHPMyAdmin 主页 上 , 单 击 “ 用 户 ” 选 项 卡 , 在 “用 户 概 况 " 信 息 表 的 选择 用 户 列 中 (如 
图 3-5 所 示 ) 选 中 (V) 用 户 , 单 击 “ 删 除 选中 的 用 户 ” 信 息 框 中 的 “执行 "按钮 。 在 删除 用 
户 信息 时 ,也 可 以 选择 “删除 与 用 户 同名 的 数据 库 ” 。 
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2. 删除 用 户 的 MySQL 语句 


对 执行 Drop User 语句 的 用 户 要求 有 Create User 权限 。 
语句 格式 : 


Drop User < 用 户 名 1 >[@ 主 机 名 1]…… [, < 用 户 名 n >[@ 主 机 名 n]] 


此 语句 仅 删除 用 户 信 息 ,并 不 删除 与 其 同名 的 数据 库 。 
【 例 3.7】 删除 用 户 TM。 


Drop User TM@ LocalHost; 


执行 此 语句 后 ,删除 了 当前 服务 器 上 的 用 户 TM。 


3.4 用户 权限 管理 


在 MySQL 数据 库 管理 系统 中 ,要 使 每 个 用 户 按 权限 操作 数据 库 , 各 司 其 职 , 在 安装 
XAMPP 后 ,启动 Apache 服务 之 前 ,必须 修改 PHPMyAdmin 的 相关 参数 ,否则 ,每 次 都 以 用 
户 root 身份 登录 服务 器 。 

在 XAMPP 的 控制 台 ( 如 图 1-12 所 示 ) , 单 击 Apache 的 Config 一 phpMyAdmin (config. 
ine. php) 选项 ,在 config. ine. php 文件 中 找到 [' auth_type'] = “config' 配置 项 ,将 
'config' 改 为 'cookie' ,存盘 并 重新 启动 Apache 服务 ,以 后 登录 MySQL 数据 库 管理 系统 
时 ,系统 要 求 输入 用 户 名 及 密码 。 

MySQL 数据 库 管理 系统 的 初始 用 户 root 有 全 部 全 局 权限 ,用 户 名 是 公开 的 ,初始 无 
密码 。root 可 以 对 数据 库 进 行 任何 操作 ,如 创建 用 户 ,数据库 和 数据 表 , 删 除 用 户 .数据 库 
和 数据 表 , 用 户 授权 数据 表 结 构 维 护 和 数据 维护 等 ,权限 范围 相当 大 ,很 容易 被 黑客 利 
用 。 因 此 ,在 MySQL 数据 库 管 理 系统 正式 启用 之 前 ,为 数据 安全 起 见 , 应 该 先 添加 必要 的 
用 户 ( 如 gly、ywy 和 ypry 等 ) ,并 授予 一 定 的 权限 后 ,立即 撤销 root 的 某 些 权限 并 添加 密 
码 。 此 后 以 其 他 用 户 的 身份 登录 并 操作 数据 库 服务 器 ,有 利于 系统 信息 安全 .用户 职责 分 
明 及 分 权限 管理 等 。 

对 MySQL 数据 库 进 行 操 作 的 用 户 , 必 须 具 有 对 应 的 权限 。 新 添加 的 用 户 登 录 到 
MySQL 服务 器 后 ,权限 有 限 ,往往 不 能 满足 实际 应 用 的 要 求 , 因 此 ,需要 为 每 个 新 用 户 授 
予 必要 的 访问 数据 库 权 限 。 用 户 权限 的 对 象 范围 分 全 局 .数据库 和 数据 表 ( 视 图) 等 , 通 
过 PHPMyAdmin 可 视 化 窗口 操作 和 执行 MySQL 语句 均 可 以 管理 用 户 权限 。 实 施 授权 操 
作 或 执行 授权 语句 的 用 户 ,需要 具有 几乎 全 部 权限 。 


3.4.1 用 户 授权 的 操作 


MySQL 的 用 户 权限 及 其 说 明 如 表 3-1 所 示 。 
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表 3-1 常用 MySQL 用 户 的 权限 表 







































































权限 类 型 权限 名 称 权限 说 明 数据 库 表 
i 查看 数据 库 , 查 询 数据 表 、 视 图 中 的 数据 以 及 G © 
用 户 信 息 及 权限 等 

Insert 向 数据 表 中 增加 数据 记录 © © 

数 据 | Update 修改 数据 表 中 的 数据 © © 
Delete 删除 数据 表 中 的 数据 记录 © © 
File 数据 导入 /导出 到 文件 
Create 创建 数据 库 及 数据 表 © © 
Alter 修改 数据 库 及 数据 表 的 结构 © © 
Index 创建 和 删除 索引 © © 
Drop 删除 数据 库 数据 表 和 视图 © © 
Te ep | 创建 临时 表 © 

结 构 | Show View 查看 视图 名 称 © © 
Create Routine 创建 存储 过 程 及 也 数 © 
Alter Routine 修改 存储 过 程 及 函数 © 
Execute 执行 存储 过 程 及 函数 © 
Create View 创建 视图 © © 
Event 设置 事件 © 
Trigger 创建 和 删除 触发 器 © © 
Grant 添加 用 户 和 为 用 户 授 权 © © 
Shutdown 关闭 数据 库 服 务 器 
Show DataBases ”| 查看 数据 库 列表 

人 Lock Tables 锁定 数据 表 © 
References 创建 数据 表 的 外 键 及 关联 © © 
Create User 创建 用 户 














在 “用 户 概 况 " 信 息 表 中 ( 如 图 3-5 所 示 ) , 单 击 待 授权 用 户 信息 (如 gly@ LocalHost) 
行 的 “编辑 权限 "按钮 ,进入 编辑 用 户 全 局 权限 的 窗口 如 图 3-7 所 示 。 


1. 授予 全 局 权限 


一 个 服务 器 中 可 能 有 多 个 数据 库 , 全 局 权限 是 指 能 操作 当前 服务 器 中 所 有 数据 库 及 
其 各 类 对 象 (数据 表 视图. 关联、 存储 过 程 和 存储 函数 等 ) 的 相关 权限 。 表 3-1 中 的 权限 
都 是 全 局 权限 。 
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编 竹 权 限 : 用 户 9/y@/ocalhost' | 





芷 语 : MySQL 检 腺 襄 凉 会 以 志文 旺 开 


四 EEC [| 











| seiecr CREATE GRANT 
| INSERT ALTER 回 supER 
| vepAre 回 TINDEX 回 PRocEss 
DELETE 回 poe 口 aeroap 
| FILE 回 cREATE TEMPORARY TABLES 回 siHuTDOwN 
| 回 sHOW VIEW 回 sHOW DATABASES 
| | BcREATE ROUTINE 口 zocg TABLES 
回 ALTER ROUTINE 回 REFERENCES 
回 gxEcUTE 口 REPLICATION CLIENT 
| CREATE VIEW 口 REPLICATION SLAVE 
| 回 eveNm 回 cREATE USER 
| © TRIGGER 
一 一 | 资源 限制 


芷 让 : 吉 入 闪 尝 渤 硕 训 为 0( 于) 即 

MAX QUERIES PER HOUR | 
0 
| MAX UPDATES PER HOUR 
Me 
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MAX CONNECTIONS PER 




















HOUR|O 
MAX USER_CONNECTIONS 
jo 








图 3-7 “编辑 权限 "窗口 的 “全 局 权限 "信息 框 


给 用 户 ( 如 gly@ LocalHost) 授予 全 局 权限 ,能 使 该 用 户 对 服务 器 中 的 所 有 数据 库 具 有 
相同 的 操作 权限 。 在 “编辑 权限 "窗口 的 “全 局 权限 "信息 框 中 (如 图 3-7 所 示 ) ,选中 (V) 
相关 权限 名 称 ( 如 Select Create 和 Grant 等 ) ,最 后 单 击 “ 执 行 "按钮 , 即 完成 用 户 的 全 局 权 
限 的 授权 。 


2. 授予 数据 库 权 限 


数据 库 权 限 是 指 操作 某 个 数据 库 及 其 所 有 对 象 的 相关 权限 ,要 比 全 局 权限 少 一 些 ， 
表 3-1 中 的 “数据 库 ? 列 中 标注 O ”的 权限 都 是 数据 库 权 限 。 

在 “用 户 概况 "信息 表 中 (如 图 3-5 所 示 ) , 单 击 要 授权 用 户 ( 如 ywy@ LocalHost) 行 的 
“编辑 权限 ”按钮 ,在 “编辑 权限 ”窗口 的 “ 按 数 据 库 指定 权限 ”信息 框 中 ,选择 已 经 存在 的 
数据 库 名 或 输入 目前 还 不 存在 的 数据 库 名 ,如 图 3-8 所 示 , 单 击 * 执 行 "按钮 。 








[一 | 按 数 据 库 指定 权限 | 
数据 库 权限 ”授权 按 表 指定 权限 操作 
mysql USAGE 否 是 多 编辑 权限 
在 下 列 数据 库 添加 权限 ; [使 用 文本 域 司 Pcz @ 





























图 3-8 “编辑 权限 "窗口 的 “ 按 数 据 库 指定 权限 "信息 框 
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在 “编辑 权限 -数据 库 ” 窗口 中 ,与 图 3-7 类 似 , 选 中 (V ) 相关 权限 名 ,最 后 单 击 “ 执 
行 " 按 钮 , 便 授 予 了 当前 用 户 ( 如 ywy@ LocalHost) 对 所 选 数据 库 ( 如 RCZP) 的 相关 操作 
权限 。 


3. 授予 数据 表 或 视图 权限 


在 “编辑 权限 -数据 库 " 窗 口 ,选择 或 输入 数据 表 或 视图 名 还 可 以 进一步 为 用 户 授予 
数据 表 权 限 ,操作 方法 与 数据 库 权 限 类 似 。 表 3-1 中 的 “ 表 " 列 中 标注 “O ”的 权限 即 为 数 
据 表 权 限 。 

给 用 户 授予 权限 的 过 程 中 ,为 用 户 授予 较 大 范围 对 象 的 权限 后 ,就 不 再 授予 其 较 小 范 
围 的 相同 权限 。 例 如 ,将 全 局 权限 Select Create 和 Grant 等 授予 用 户 gly@ LocalHost ,不 再 
将 某 个 数据 库 或 数据 表 的 这 些 权 限 重复 授予 gly@ LocalHost; 同样 ,将 数据 库 RCZP 的 某 
些 权限 授予 用 户 ywy@ LocalHost 后 ,也 没 必要 再 将 RCZP 中 数据 表 的 权限 授予 该 用 户 。 


3.4.2 用户 授 权 的 语句 


在 MySQL 中 ,执行 SQL 的 数据 访问 控制 语言 的 Grant( 授权) 语句 也 能 授予 用 户 
权限 。 
语句 格式 : 
Grant < 权限 名 称 表 1 >on < 对 象 范围 > 
To < 用 户 名 1 >[Identified By < 密码 1 习 [@ < 主机 名 工 习 
[,……， < 用 户 名 n >[Identified By < 密码 n 习 [@ < 主机 名 mn 习 ] 


1. 权限 名 称 


权限 名 称 (如 表 3-1 所 示 ) 用 于 说 明 要 授予 用 户 的 权限 ,此 外 ,还 可 以 用 Al 
[Privileges ] 短语 表示 全 部 权限 。 

【 例 3.8】 给 用 户 ypry@'%' (其 他 计算 机 用 户 ) 仅 授予 数据 库 RCZP 的 查询 
(Select) .增加 (Insert) 和 修改 ( Update ) 记 录 的 权限 ;为 用 户 gly@ LocalHost( 当前 服务 器 用 
户 ) 授予 所 有 全 局 权限 。 


Grant Select, Insert, Update On RCZP.* To ypry /* 省 略 主机 名 表示 @'$' */; 
Grant All On * .* To gly@ LocalHost; 


2. 对 象 范围 


对 象 范围 用 于 说 明 人 允许 用 户 操作 哪些 对 象 , 有 下 列 4 种 常用 选项 : 

(1) * : 表示 当前 数据 库 中 的 所 有 对 象 (包括 数据 表 .视图 .存储 过 程 和 函数 等 ) 。 

(2) * . * : 表示 当前 服务 器 中 所 有 数据 库 中 的 各 种 对 象 , 即 全 局 权限 。 

(3) < 数据 库 名 >. * : 表示 指定 数据 库 中 的 所 有 对 象 , 即 数据 库 权 限 。 可 以 指定 尚 
不 存在 的 数据 库 名 。 
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(4) < 数据 库 名 > . < 数据 表 或 视图 名 > : 表示 给 定数 据 库 中 的 某 个 数据 表 或 视图 ， 
即 数 据 表 权 限 。 可 以 指定 尚 不 存在 的 数据 库 数据 表 或 视图 。 

【 例 3.9】 授予 用 户 ypry@ '% ' 对 数据 库 RCZP 中 的 视图 GWPJF 有 查询 权 
( Select) ;授予 用 户 ywy@ LocalHost 全 权 操 作 数 据 库 RCZP。 


Grant Select On RCZP.GHPJF To ypry; 
Grant All On RCZP. * To ywy@ LocalHost; 


3. 主机 名 


主机 名 用 于 说 明 被 授权 用 户 所 在 的 主机 名 ,可 以 选用 *'%' "或 LocalHost 之 一 ,省 略 
时 表示 ' %' , 即 其 他 计算 机 。 


4. 用 户 名 


用 户 名 用 于 说 明 被 授权 的 用 户 。 当 对 应 的 主机 上 不 存在 该 用 户 时 ,系统 自动 添加 用 
户 信 息 , 并 通过 Identified By < 密码 > 短语 可 以 设置 密码 。 

【 例 3.10】 添加 当前 服务 器 的 游客 用 户 YK ,无 密码 ,对 数据 库 RCZP 中 的 所 有 对 象 
只 有 查询 数据 的 权限 。 


Grant Select On RCZP. * To YK@ LocalHost; 


3.4.3 检查 权限 

在 MySQL 数据 库 管理 系统 中 ,可 以 从 用 户 和 数据 库 两 个 不 同 的 角度 检查 授权 情况 ， 
只 要 有 Seleet 权限 ,用 户 就 可 以 检查 用 户 的 权限 。 

1. 检查 用 户 权限 的 操作 


在 PHPMyAdmin 主页 上 , 单 击 “ 用 户 " 选 项 卡 ,在 “用户 概况 "信息 表 中 (如 图 3-5 所 
示 ) ,通过 “全 局 权限 " 列 可 以 查看 授予 各 个 用 户 的 全 局 权限 情况 ,其 中 Usage 表示 目前 还 
没有 授权 ;Al Privileges 表示 全 部 全 局 权限 。 单 击 用 户 ( 如 ywy 或 ypry ) 行 的 “编辑 权限 ” 
按钮 ,在 “编辑 权限 "窗口 中 可 以 进一步 查看 该 用 户 的 数据 库 及 数据 表 权 限 。 


2. 检查 用 户 权 限 的 语句 

语句 格式 : 

Show Grants For < 用 户 名 >[@ < 主机 名 习 

【 例 3.11】 查看 用 户 ywy@ LocalHost 的 权限 。 
Show Grants For ywy@ LocalHost; 

输出 结果 如 表 3-2 所 示 。 
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表 3-2 ”用户 ywy@LocalHost 的 权限 表 


Grants for ywy@ localhost 说 明 





GRANT USAGE ON * . * TO "ywy @ "localhost 没有 全 局 权限 





GRANT ALL PRIVILEGES ON iczp- * TO 'ywy'@'localhosr | 数据 库 rezp 的 全 部 操作 权限 





GRANT SELECT, SHOW VIEW ON ”mysql > * TO ywy @ 数据 库 mysql 的 查询 数据 和 视图 权限 


"localhost 





3. 检查 数据 库 权 限 的 操作 


在 PHPMyAdmin 主页 上 , 单 击 “ 数 据 库 " 选 项 卡 一 数据 库 ( 如 mysql) 行 的 “检查 权限 ” 
按钮 ,显示 可 以 访问 当前 数据 库 的 用 户 名 .权限 范围 和 权限 名 称 , 如 图 3-9 所 示 。 


| 马 用 户 可 以 访问 “mysql" 
用 主机 类 权限 授 操作 
户 型 权 
gly ”localhost 全 局 sELECT，INSERT，UPDATE，DELETE，CREATE,， 是 入 编辑 权限 
DROP， REFERENCES, INDEX, ALTER, CREATE 
TEMPORARY TABLES, CREATE VIEW, EVENT, 
TRIGGER, SHOW VIEW, CREATE ROUTINE, ALTER 
ROUTINE, EXECUTE 
root linux 全 局 ALL PRIVILEGES 是 名 编辑 权限 
root localhost 全 局 ALL PRIVILEGES 是 委 编辑 权限 
ywy localhost 按 数 SELECT， SHOW VIEW 否 氏 编辑 权限 
据 库 
指定 











图 3-9 用 户 可 以 访问 数据 库 的 权限 信息 框 


3.4.4 撤销 用 户 的 权限 


撤销 权限 是 授予 权限 的 逆 操 作 ,实施 撤销 权限 的 用 户 也 要 有 授权 用 户 的 权限 。 


1. 撤销 权限 的 操作 

在 “编辑 权限 "窗口 的 相关 信息 框 中 (如 图 3-7 所 示 ) ,不 选 (去 掉 V ) 相关 权限 名 称 ， 
单 击 * 执 行 " 按钮 , 即 可 撤销 当前 用 户 的 相关 权限 。 

2. 撤销 权限 的 语句 


执行 SQL 中 数据 访问 控制 语言 的 Revoke( 撤销 权限 ) 语 句 也 能 撤销 用 户 的 相关 权限 。 

语句 格式 : 

Revoke < 权限 名 称 >[ 字段 名 表 >] on < 对 象 范围 于 rom < 用 户 名 >[@ 主 机 名 ] 

语句 的 主要 功能 是 撤销 用 户 的 权限 ,是 Grant 语句 功能 的 逆 操 作 。 权 限 名 称 同 样 可 
以 用 Al [ Privileges ] 短语 撤销 全 部 权限 。 
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【 例 3.12】 撤销 图 3-9 中 的 最 后 一 行 权 限 。 
Revoke Select，Show View On MySQL. * From ywy@ LocalHost; 


数据 库 中 的 每 个 用 户 都 应 该 具有 一 定 的 权限 ,在 数据 库 管 理 系统 运行 过 程 中 ,可 能 经 
常 需要 通过 Grant 和 Revoke 语句 进行 用 户 权 限 管理 。 从 数据 保密 和 信息 安全 的 角度 出 
发 ,对 一 些 暂时 不 需要 的 用 户 ,特别 是 一 些 公开 的 容易 泄密 的 用 户 ( 如 root) ,要 尽量 不 
授予 对 数据 容易 造成 破坏 的 权限 ,如 Grant Create 、Alter、 Drop \ Insert Update 和 Delete 
等 权限 ,必要 时 可 以 撤销 这 类 用 户 的 一 切 权限 ,经常 修改 密码 ,或 者 从 系统 中 删除 这 类 
用 户 。 


3.5 ”数据 库 管理 


数据 库 是 包含 数据 表 、 视 图 .关联 和 存储 过 程 ( 函数 ) 等 对 象 的 容器 。 数 据 库 管理 包 
括 创建 查看 和 删除 数据 库 以 及 选择 当前 数据 库 等 操作 。 


3.5.1 创建 数据 库 


在 MySQL 数据 库 管理 系统 中 ,一 个 数据 库 对 应 一 个 文件 夹 (与 数据 库 同 名 ) ,简称 数 
据 库 文件 夹 。 在 系统 默认 情况 下 ,数据 库 文件 夹 存 于 “…XAMPP\MySQL\Data” 文件 来 
下 ,如 图 3-10 所 示 。 除 由 和 test 外 ,cdcol、performance_schema 和 mysql 都 是 系统 数据 库 ， 
用 于 存储 用 户 及 其 数据 库 的 相关 信息 ,不 要 将 其 删除 ,否则 ,可 能 造成 系统 运行 失常 。 

创建 数据 库 的 用 户 要 有 Create 权限 。 创 建 数据 库 ( 如 RCZP) 时 ,系统 自动 创建 数据 
库 文 件 夹 (如 XAMPP\MySQL\Data\RCZP) ,同时 在 其 下 产生 db. opt, 存 储 数据 库 的 相关 
参数 。 


1. 创建 数据 库 的 操作 


在 PHPMyAdmin 主页 上 , 单 击 “ 数 据 库 ” 选 项 卡 , 在 “数据 库 " 信 息 窗口 中 输入 数据 库 
名 (如 RCZP) ,选择 字符 集 规则 ( 如 utf8_general_ci) 等 信息 ,如 图 3-11 所 示 , 最 后 单 击 “ 创 
建 " 按 钮 , 即 可 创建 一 个 空 数据 库 。 

数据 库 名 一 般 要 遵循 文件 夹 的 命名 规则 。 字 符 集 规则 用 于 说 明 数 据 表 中 数据 的 符号 
规则 , 初 值 是 “整理 " , 即 , 由 数据 库 默 认 的 字符 集 决定 。 为 了 能 正常 处 理 及 显示 数据 库 中 
的 中 文 信息 (数据 表 名 、 字 段 名 及 数据 记录 ) ,要 选择 适当 的 字符 集 。utf8_general_ci 和 
utf8_unicode_ci 适合 多 种 语言 (包括 中 文 ) ;gb2312_chinese_ci 和 gbk_chinese_ci 适合 简体 
中 文 。 字 符 集 名 中 的 英文 字母 不 区 分 大 小 写 。 
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字符 集 规则 选择 框 




































































光 / 1 大 
文件 x 效 据 库 
日 四 xpp | 局 新 建 数据 库 局 
国 回 anonmous 
国 回 apache RCZzP utf8_general_ ci ”图 创建 ] 
BD cei-bi 
Be 数据 库 
| ea cdcol 本 检查 权限 
licenses 引 information_schema ”检查 权限 
国 回 lecale 
DB wailoatpat 司 mysql 到 检查 权限 
nailtodisk 
日 固 wzsql 数据 库 选 择 列 一 一 performance_schema 检查 权限 
本 入 ee phpmyadmin 到 检查 权限 
SQ 口 | 中 检查 权限 
cdcol 
Bsa 器 ltest 辕 检 查 权限 
DY perfornance_schena 
henryenia 口 |webauth al 检查 权限 
外 总 计 : 8 
四 | 下 到 全 寺 /全 不 选 雳 力克。 国 删除 
图 3-10 ”数据库 文 件 夹 图 3-11 “数据 库 " 信 息 窗口 


2. 创建 数据 库 的 语 名 


语句 格式 : 


Create DataBase |Schema [If Not Exists] < 数据 库 名 > 
[Character Set [ =] 入 符 集 名 习 


各 个 短语 的 含义 如 下 : 
(1) DataBase1Schema: Create DataBase( 数据 库 ) 或 Create Schema( 模式 ) 含 义 相 同 ， 


都 表示 创建 数据 库 。 


(2) If Not Exists: 当 所 要 创建 的 数据 库 已 经 存在 时 ,如 果 再 执行 不 含 ff Not Exists 短 
语 的 Create DataBase1Schema 语句 , 则 系统 产生 出 错 信息 ;如 果 执 行 含 ff Not Exists 短语 的 
Create DataBase1Schema 语句 , 则 系统 放弃 执行 该 语句 ,系统 并 不 产生 出 错 信 息 。 

(3) 字符 集 名 : 数据 库 所 使 用 的 字符 集 名 称 的 缩写 ,如 utf8 、gb2312 或 GBK ,需要 用 


单 引号 或 双 引号 引起 来 。 


【 例 3.13】 创建 人 才 招 聘 数 据 库 RCZP ,数据 库 中 的 数据 采用 字符 集 utf8。 


Create DataBase RCZP Character Set ="UTF8" 


/* 可 以 省 略 * 一 和 单 引号 * /; 


执行 此 语句 时 ,车 数据 库 RCZP 已 经 存在 , 则 系统 将 提示 出 错 信息 。 在 语句 中 加 下 
Not Exists 短语 ,可 以 避免 产生 这 种 现象 。 


3.5.2 选择 当前 数据 库 


一 个 服务 器 中 可 能 有 多 个 数据 库 ,但 是 ,在 处 理 某 个 任务 的 信息 时 ,往往 只 需要 
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同一 


个 数据 库 中 的 数据 。 为 了 简化 操作 ,对 一 个 数据 库 ( 如 RCZP) 中 的 对 象 (数据 表 、 视 图 和 
存储 过 程 等 ) 进 行 操作 之 前 ,通常 要 使 其 成 为 当前 数据 库 。 在 写 MySQL 语句 时 ,所 涉及 的 
当前 数据 库 中 的 对 象 名 前 可 以 省 略 数据 库 名 和 圆 点 。 


1. 选择 当前 数据 库 的 操作 


有 Select 权限 的 用 户 , 在 PHPMyAdmin 主页 (如 图 3-2 所 示 ) 或“ 数据库" 信息 窗口 
(如 图 3-11 所 示 ) , 单 击 数据 库 名 (如 RCZP) 均 可 进入 当前 数据 库 窗 口 ,如 图 3-12 所 示 。 
更 换 当前 数据 库 的 下 拉 框 选择 数据 表 列 所 在 行 对 象 的 操作 工具 
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图 3-12 ”当前 数据 库 信息 窗口 


对 于 有 更 多 权限 的 用 户 , 在 当前 数据 库 窗 口 可 以 修改 数据 库 , 新 建 , 修 改 (数据 表 结 
构 ) ,浏览 (输入 和 查看 ) .删除 或 清空 数据 表 等 。 


2. 选择 当前 数据 库 的 语句 
语句 格式 : 
Use < 数据 库 名 > 


数据 库 名 必须 是 已 经 存在 的 数据 库 。 执 行 此 语句 后 ,使 指定 的 数据 库 成 为 当前 数 
据 库 。 
【 例 3.14】 选择 RCZP 为 当前 数据 库 。 


Use RCZP; 
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3.5.3 修改 数据 库 


通过 修改 数据 库 可 以 实现 数据 库 更 名 和 重新 调整 数据 库 的 字符 集 , 但 新 的 字符 集 只 
对 以 后 创建 的 数据 表 起 作用 。 调 整数 据 库 字符 集 的 用 户 必须 有 Alter 权限 ;数据 库 更 名 的 
用 户 必须 有 Create 和 Drop 权限 。 


1. 修改 数据 库 的 操作 


在 当前 数据 库 信 息 窗 口 (如 图 3-12 所 示 ) , 单 击 * 操 作 "选项 卡 ,在 “将 数据 库 改名 为 ” 
信息 框 中 输入 数据 库 新 名 ,或 者 ,在 “整理 "信息 框 中 选择 调整 后 的 字符 集 名 称 ,最 后 单 击 
对 应 信息 框 中 的 “执行 "按钮 。 


2. 修改 数据 库 字 符 集 的 语句 

语句 格式 : 

Alter DataBase |Schema [ < 数据 库 名 >] Character Set [=] < 他 符 集 名 > 

此 语句 主要 用 于 重新 调整 数据 库 的 字符 集 名 称 , 若 调整 当前 数据 库 的 字符 集 , 则 数据 


库 名 可 以 省 略 。 
【 例 3.15】 将 数据 库 RCZP 的 字符 集 调整 为 gbk_chinese_ci 
Use RCZP; 
Alter DataBase Character Set GBK; /* GBK 为 gok_chinese ci 的 缩写 * / 


3.5.4 删除 数据 库 


删除 用 户 时 ,可 以 选择 删除 与 用 户 同 名 的 数据 库 , 此 外 ,还 可 以 通过 专门 的 操作 或 
MySQL 语句 删除 数据 库 。 无 论 采 用 哪 种 方式 删除 数据 库 ,都 将 删除 数据 库 文件 夹 .数据 
表 等 与 数据 库 相 关 的 信息 。 


1. 删除 数据 库 的 操作 


执行 删除 数据 库 操作 的 用 户 ,必须 具有 Select 和 Drop 权限 。 

(1) 删除 当前 数据 库 的 操作 : 在 当前 数据 库 信 息 窗口 (如 图 3-12 所 示 ) , 单 击 “ 操 作 ” 
选项 卡 一 “删除 数据 库 " 选 项 一 “确定 "按钮 。 

(2) 删除 多 个 数据 库 的 操作 : 在 “数据 库 " 信 息 窗口 的 数据 库 选择 列 (如 图 3-11 所 
示 ) 中 选中 (V) 数 据 库 名 (如 由 和 test 等 ) 后 , 单 击 “ 删 除 " 一 “是 "按钮 。 


2. 删除 数据 库 的 语句 


执行 删除 数据 库 语 句 的 用 户 ,必须 具有 Drop 权限 。 
语句 格式 : 
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Drop DataBase |Schema [If Exists] < 数据 库 名 > 


加 了 f Exists 短语 ,可 以 避免 由 于 被 删除 的 数据 库 不 存在 而 引发 系统 出 错 。 


3.6 创建 数据 表 


一 个 数据 库 中 可 以 包含 多 个 数据 表 ( 也 简称 表 ) ,每 个 数据 表 中 都 包含 若干 个 字段 和 
记录 , 即 , 每 个 数据 表 都 由 数据 表 结 构 和 数据 记录 两 部 分 内 容 构成 ,以 文件 (扩展 名 为 
frm, 如 公司 表 . frm 和 gwb. frm 等 ) 的 形式 存储 于 数据 库 文件 夹 中 。 

创建 数据 表 是 对 关系 模式 实施 物理 设计 ,主要 包括 创建 数据 表 结 构 .设置 关键 字 及 主 
键 等 操作 。 在 向 数据 表 中 输入 数据 记录 之 前 ,要 先 创 建 数据 表 。 创 建 数据 表 的 用 户 需 要 
有 Create 权限 。 


3.6.1 创建 数据 表 结 构 的 操作 


在 当前 数据 库 信息 窗口 中 ( 如 图 3-12 所 示 ) , 单 击 “ 新 建 数据 表 " 按 钮 ,在 “新 建 数 据 
表 结 构 " 窗 口中 ( 如 图 3-13 所 示 ) ,系统 初始 给 出 4 个 空白 行 , 即 可 以 设计 4 个 字段 。 当 设 
计 包含 更 多 字段 的 数据 表 时 ,可 以 输入 "添加 ”的 字段 个 数 (默认 为 1) ,再 单 击 “执行 ” 
按钮 。 






































































































































数据 表 名 : [公司 表 ] 添加 [1 |] 个 字段 
结构 
名 字 类 型 日 长 度 / 值 ”默认 整理 属性 空 索引 ww 
可 称 | [VARCHAR 国 [40 | [ 殉 国 图 [ 国 口 [ERiMApy 辆 日 
地 址 VARCHAR 图 则 5o 无 的 ~ 国友 --- 图 口 
注册 日 期 DATE 图 玩 图 图 ~ Ss 国 日 
注册 人 数 SMALLINT 图 串 5 定义 : 图 图 ”Lunsicneo 国 i 同 口 
100 
[ 芭 牙 编码 | [CHAR 国 [6 区 国 | | 四 过 国 日 
注销 BOOLEAN 图 定义 : ~ ~ ~ Ee 加 口 
0 
公司 简介 | [LONGTEXT 加 [ ”| 区 国 [ ~ 国 回 [--- 国 ”日 
宣传 片 LONGBLOB 国 无 图 | ~ 加 --- 同 口 





图 3-13 “新 建 数据 表 结 构 " 窗 口 


在 图 3-13 中 输入 数据 表 名 (如 公司 表 ) ,各 行 字段 “名 字 ”\ 数 据 * 类 型 ”和 ”长 度 / 值 
等 信息 。 最 后 单 击 “ 保 存 ” 按 钮 , 即 可 创建 数据 表 。 
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1. 数据 表 名 


数据 表 名 ( 如 公司 表 、GWB 和 YPRYB 等 ) 指出 要 创建 的 数据 表 , 数 据 表 的 命名 规则 
必须 符合 Windows 中 文件 名 的 规定 ,但 是 ,数据 表 名 中 包含 某 些 特殊 符号 会 给 应 用 带 来 许 
多 不 便 。 例 如 ,分 隔 符 ( 如 空格 . 圆 点 .逗号 .分 号 .冒号 单 双 引 号 等 ) 和 运算 符 ( 如 +、-、 
* /等 ) 都 是 特殊 符号 。 如 果 数 据 表 名 中 一 定 要 使 用 这 些 特殊 符号 ,在 使 用 数据 表 时 必 
须 用 左 单 引号 “> 将 其 引起 来 。 

要 创建 的 数据 表 在 当前 数据 库 中 已 经 存在 时 , 单 击 * 保 存 "按钮 ,系统 将 提示 出 错 信 
息 , 但 并 不 覆盖 原 有 数据 表 。 


2. 名 字 


名 字 是 指数 据 表 中 的 字段 或 列 名 称 ( 如 公司 名 称 和 地 址 等 ) ,字段 名 中 的 符号 通常 由 
英文 字母 汉字 ,数字 或 下 画 线 组 成 , 首 字 符 一 般 不 为 数字 。 字 段 名 最 大 长 度 可 为 64 个 字 
符 或 汉字 。 如 果 字 段 名 中 使 用 某 些 特殊 符号 ,处理 方法 则 和 上 述 数 据 表 名 中 特殊 符号 的 
处 理 方法 相同 ,也 用 左 单 引 号 引起 来 。 

一 个 数据 表 中 至 少 包含 1 个 字段 ( 列 ) ,可 包含 500 多 个 字段 ,但 是 ,不 能 出 现 两 个 同 
名 字段 。 男 外 ,字段 个 数 太 多 也 可 能 导致 系统 速度 显著 变 慢 。 


3. 长 度 / 值 


长 度 / 值 是 指 对 应 字段 能 存储 数据 的 最 大 长 度 (宽度 ) ,最 小 值 为 1。 有 些 数据 类 型 
(如 Date 和 Text 等 ) 的 字段 不 需要 用 户 定义 长 度 , 由 系统 规定 长 度 ; 另 一 些 数据 类 型 
(如 ENum 和 Set) 需 要 输入 具体 值 ,例如 ,对 最 低 学 历 码 字段 ,需要 输入 “'1','2','3'， 
Ws 


3.6.2 字段 的 数据 类 型 


数据 表 中 每 列 (字段 ) 都 有 各 自 的 数据 类 型 ,用 于 统一 说 明 该 列 各 行 ( 记录) 数据 的 性 
质 和 最 大 长 度 。 常 用 的 数据 类 型 可 以 归纳 为 数值 型 .字符 串 ( 文 本 ) 型 和 日 期 时 间 型 。 在 
“新 建 数据 表 结构 "窗口 (如 图 3-13 所 示 ) 的 “类 型 "下 拉 列 表 中 ,可 以 选择 当前 字段 的 数 
据 类 型 (如 TinyInt Double .Date 或 Char 等 ) 。 


1. 数值 型 


数值 型 (如 TinyInt 和 Double 等 ) 常 数 由 0 ~9 小 数 点 (整数 无 小 数 点 ) 和 正 负 号 (无 
符号 数 除外 ) 组 成 ,也 可 以 用 科学 计数 法 rEm 的 形式 表示 ,其 中 为 实数 ,m 为 整数 。 如 
2015 .3. 14 ,2.5E3( 表 示 2.5 x103 ) 等 都 是 数值 型 常数 。 

数值 型 数据 是 指 能 用 于 算术 运算 的 数据 ,可 以 是 正 数 或 负数 。 根 据 数据 是 否 带 小 数 
点 ,又 可 以 分 为 实数 型 和 整数 型 两 种 。 对 数值 型 数据 还 可 以 进一步 说 明 为 无 符号 数据 
( Unsigned ,大 于 或 等 于 0 的 数 ) 。 
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(1) 实数 型 是 带 有 小 数 的 数据 ,如 3.14.2.5 和 9.18 等 。 根据 表示 的 数据 范围 大 小 ， 
又 可 以 细 分 为 Decimal .Double 和 Float 等 ,如 表 3-3 所 示 。 
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表 3-3 实数 型 











类 型 描述 说 明 数据 范围 举例 
范围 由 M 和 D 动态 决定 。 默 认 长 度 
Decimal[(M,D) ] | 可 变 实 数 , 占 8B | (MD) 为 10 位 ,最 大 长 度 为 65 位 ;默认 小 | 重量 Decimal(20,5) 
数 (D) 为 0 位 ,小 数 最 多 30 位 
省 略 D 和 M, 整 数 和 小 数位 数 由 实际 存 
Real[(M,D)] 双 精 度 浮 点 数 ，| 储 的 数据 确定 。 最 大 长 度 (M)255 位 ; 单价 Real 
可 和 be 和 eal(10,2) 
Double[ (M,D)] | 占 8B 小 数 (D) 最 多 30 位 。 精 度 为 15 位 小 
数 , 即 小 数 超过 15 位 时 可 能 出 现 误差 
单 精 度 浮 点 数 ，| 除 小 数 精度 比 Double 位 数 少 外 ,其 余 与 | ,.。 
Float[ (M,D)] 下 Double 相同 所 得 税 Float(8,2) 











表 中 M 表述 数据 总 位 数 ,D 为 小 数位 数 ,符号 和 小 数 点 均 不 占 位 数 。 在 实际 应 用 中 ， 
实数 型 也 可 以 是 无 符号 (Unsigned) 数 据 ,存储 大 于 或 等 于 0 的 数据 。 对 某 个 字段 ( 如 所 得 
税 ) 选 择 实数 型 (如 Float) 后 ,长 度 应 该 输入 一 对 数 ( 如 *8,2” ) 。 

(2) 整数 型 是 不 含 小 数 的 数据 ,如 100 和 3 等 。 根 据 表示 的 数据 范围 大 小 ,又 分 为 
TinyInt Boolean 和 Int 等 。 如 表 3-4 所 示 。 其 中 Boolean 也 称 为 逻 辑 型 ,用 于 存储 逻辑 型 

















数据 ,与 TinyInt(1) 等 效 。 
表 3-4 ”整数 型 
es A 无 符号 ( Unsigned) >; 
类 型 描述 说 明 有 符号 数据 范围 数据 范围 举例 
人 | 微小 整数 ， 闪闪 和 全 (和 | 默认 长 度 3 位 , 取 值 范 | 年龄 上 限 Tinyim(2) 
[GD] jh 2 国 为 128 ~ 127。 可 丰 ae 人 数 TinyInt Unsigned 
储 气 象 温度 .风力 等 De 
ee 注销 Boolean 
Boolean 自动 转换 为 0 表示 假 , 非 0 表示 真 
Tinymt(1) 资格 审核 Boolean 
默认 长 度 6 位 , 取 值 范围 注册 人 数 SmallInt 
SmallInt 较 小 的 整 | 为 -32768~32767。 可 有 i Unsigned 
[(M)] 数 , 占 2B ”| 存储 日 销售 商品 件数 . 营 储 公司 人 数 等 ° E 
业 额 等 件数 SmallInt Unsigned 
默认 长 度 8 位 , 取 值 范围 为 | 默认 长 度 8 位 , 取 值 范 | 年 薪 MediumInt 
MediumInt | 中 等 整数 ,| -8388 608~8388 607。 可 | 围 为 0 ~ 16 777 215。| Unsigned 
[(M)] 占 3B 存储 中 等 借贷 金额 .年 净 | 可 存储 城市 人 口 数 .图 
利润 等 书 印 数 等 借贷 金额 MediuomInt 
标准 整数 pa 4 地 | 上 认 长 度 10 位 , 取 值 东 
Int[ (M)] 占 4B ”| > 147 483 67 可 存储 较 围 为 0 ~4 294 967 295。| 年 净利 润 mt(10) 
可 存储 国家 人 口 数 等 
大 借贷 金额 ,年 净利 润 等 
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( 续 表 ) 








类 型 描述 | 。 说 明 有 符号 数据 范围 。 | 无 符号 (Unsigned) 举例 
数据 范围 
默认 长 度 20 位 , 取 值 范 | 。、 ,。 
BigInt 大 整数 ， 围 为 -9 223 372 036 854 0 国民 经 济 总 产值 BigInt 
[(M)] 占 8B 775 808 ~ 9 223 372 036 OO (15) 
854 775 807 





表 中 描述 类 型 的 [ (M) ] 可 以 省 略 ,M 表示 长 度 。 如 TinyInt(4) ,M 为 4, 由 于 M 的 默 
认 长 度 为 4, 因 此 可 以 简写 成 TinyInt, 即 可 以 不 输入 长 度 ; 同 样 ,SmallInt(5) Unsigned 与 
SmallInt Unsigned 含义 相同 。 


2. 日 期 时 间 型 


日 期 时 间 型 (如 Date .Time 和 TimeStamp 等 ) 常 数 需要 用 单 引 号 或 双 引 号 引起 来 ,年 、 
月 和 日 之 间 常 用 连 字符 减 号 ” - ”、 圆 点 “. "或 斜 杠 “/”" 分 隔 ; 时 、 分 和 秒 之 间 用 连 字 符 冒 
号 *; "分 隔 , 日 期 与 时 间 之 间 用 逗号 或 空格 分 隔 。 如 '1949-10-1 表示 1949 年 10 月 1 日 ; 
"2015.9.3,20:10:30" 表 示 2015 年 9 月 3 日 20 点 10 分 30 秒 。 

日 期 时 间 型 又 分 日 期 型 (格式 为 YYYY-MM-DD ,表示 年 -月 -日 ) .时 间 型 (格式 为 HH: 
MM :SS ,表示 时 : 分 : 秒 ) 和 日 期 时 间 型 (格式 为 YYYY-MM-DD HH:MM:SS) 三 种 类 型 。 
对 某 个 字段 (如 出 生 时 间 笔试 日 期 ) 选择 日 期 时 间 型 (如 DateTime 或 Date ) 后 ,不 需要 输 
和信 长度, 由 系统 规定 其 长 度 。 常 用 类 型 如 表 3-5 所 示 。 























表 3-5 日 期 时 间 型 
类 型 描述 说 明 数据 范围 举例 
Date dei ED 0000-0-0 ~ 9999-12-31 “| 笔试 日 期 ”Date 
-838:59:59 ~ 838: 59: 
Time et HH; MM: SS( 时 ;| 59 常用 范围 为 0:0:0 ~ | 午餐 时 间 Time 
23:59: 59 
DateT 日 期 时 间 型 ,格式 为 YYYY-MM-DD | 0001-0-0 0:0:0 ~ 出 生 时 间 
Eee HH: MM: SS 9999-12-31 23:59:59 | DateTime 
日 期 时 间 型 ,也 称 时 间 截 型 ,格式 为 
YYYY-MM-DD HH:MM:SS。 在 对 
应 字段 不 设置 默认 值 ( Default) 的 情 
A 况 下 , 当 增 加 或 修改 数据 记录 时 ,如 | 1970-1-1 0:0:0 ~ 更 新 时 间 
SS 果 不 添 加 或 修改 时 间 截 字段 的 值 ,| 2037-12-31 23:59:59 | TimeStamp 
则 用 系统 日 期 和 时 间 自 动 修改 该 类 
字段 的 值 , 即 自 动 记载 对 应 数据 记 
录 的 更 新 时 间 
3. 字符 串 型 


字符 串 型 (如 Char VarChar 和 ENum 等 ) 用 于 存储 一 段 文字 信息 。 根 据 存储 文字 的 
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多 少 , 又 分 出 多 种 数据 类 型 ,如 表 3-6 所 示 。 字 符 串 型 常数 需要 用 单 引 号 或 双 引 号 引起 
来 ,如 ' 李 明 ' " 男 "和 "大 数据 时 代 "都 是 字符 串 型 常数 。 


类 型 描述 


表 3-6 字符 串 型 
说 明 


举例 





Char(M) 


字符 串 型 ,M 表示 最 大 字符 长 度 ,0 <M<255, 即 最 多 可 
存储 255 个 汉字 或 字符 ,存储 一 个 汉字 也 占 一 个 长 度 。 
通常 用 于 存储 固定 长 度 的 数据 。 例 如 ,邮政 编码 性别、 
学 历 编码 .民族 编码 .身份 证 号 和 学 号 等 


邮政 编码 Char(6) 





VarChar( M) 


可 变 字符 串 型 ,0 < M<32 766, 当 M >32 766 时 ,自动 变 
为 其 他 类 型 (如 MediumText) 。 与 Char 的 区 别 不 仅 是 长 
度 范围 不 同 ,还 在 于 占用 的 存储 空间 。 在 数据 表 的 每 个 
记录 中 ,Char 类 型 字段 值 占用 的 存储 空间 由 M 确定 ( 固 
定 长 度 ) ,而 VarChar 类 型 字段 值 占用 的 存储 空间 由 该 字 
段 中 最 长 字符 串 的 长 度 决 定 。 例 如 ,地 址 Char(100) ,无 
论 地 址 字段 实际 存储 数据 多 长 ,占用 空间 都 是 100B; 地 
址 VarChar(100) ,与 地 址 字段 实际 存储 的 最 长 字符 串 有 
关 , 实 际 占用 的 空间 可 能 少 于 100B。 通 常用 于 存储 不 定 
长 的 数据 。 如 ,公司 名 称 和 地 址 等 


公司 名 称 VarChar( 40) 


地 址 VarChar( 50) 





ENum 


字符 串 枚 举 型 ,最 多 可 枚 举 65535 项 (字符 串 )。 在 输入 
数据 时 ,可 以 从 枚 举 项 中 选择 一 项 


最 低 学 历 ENum ,长 度 / 值 
A 








集合 型 ,最 多 可 有 64 个 枚 举 项 (字符 串 )。 在 输入 数据 
时 同 Enum 





4. 文本 型 


文本 型 (如 TinyText 和 Text 等 ) 用 于 存储 较 长 的 文字 信息 ,常数 也 需要 用 单 引号 或 双 
引号 引起 来 。 对 某 个 字段 选择 文本 型 后 ,也 不 需要 输入 长 度 , 如 表 3-7 所 示 。 


性 别 Set ,长 度 / 值 输入 : 
" 男 "," 女 " 














表 3-7 文本 型 
类 型 描述 说 明 举例 
Text 文本 型 ,最 多 可 存储 65 535 个 字符 个 人 简历 Text 
MediumText 中 等 文本 型 ,最 多 可 存储 16 777 215 个 字符 图 书 摘要 MediumText 
LongText 长 文本 型 ,最 多 可 存储 4 294 967 295 个 字符 公司 简介 LongText 





5. 二 进 制 大 对 象 型 


二 进 制 大 对 象 型 (Binary Large Object,BLOB ) 以 二 进 制 形式 存储 数据 ,可 以 存储 任何 
类 型 的 数据 。 通 常用 于 存储 图 像 .音频 或 视频 等 多 媒体 信息 。 对 某 个 字段 选择 二 进 制 大 
对 象 型 后 ,并 不 需要 输入 长 度 ,如 表 3-8 所 示 。 
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表 3-8 二 进 制 多 媒体 型 




















类 型 描述 说 明 举例 
TinyBLOB 最 多 可 存储 255 个 字 节 徽标 TinyBLOB 
BLOB 最 多 可 存储 65 535 个 字 节 照片 BLOB 
MediumBLOB 最 多 可 存储 16 777 215 个 字 节 校歌 MediumBLOB 
LongBLOB 最 多 可 存储 4 294 967 295 个 字 节 宣传 片 LongBLOB 


3.6.3 设置 字段 的 附加 属性 


在 “新 建 数据 表 结 构 " 窗 口 (如 图 3-13 所 示 ) 中 , 除 输入 数据 表 的 字段 名 和 选择 数据 
类 型 外 ,还 可 以 设置 字段 是 否 为 空 前 导 0 ,默认 值 . 自 增值 以 及 数据 表 的 主键 和 关键 字 等 


1. 空 值 ( Null) 


选中 (V) 图 3-13 的 * 空 " 列 ( 如 地 址 和 注册 日 期 等 字段 ) ,表示 在 输入 数据 记录 时 对 
应 字段 (如 地 址 和 注册 日 期 等 ) 的 值 可 以 空 ( Null 或 不 输入 ) 。 对 于 数据 表 的 主 属性 字段 
(如 公司 名 称 ) ,不 能 选中 * 空 " 列 , 即 增加 数据 记录 时 主 属性 的 值 不 能 空 。 


2. 无 符号 数 (Unsigned ) 


无 符号 数 是 指 大 于 或 等 于 0 的 数 。 在 图 3-13 的 “属性 " 列 中 ,对 某 个 数值 型 字段 ( 如 
注册 人 数 ) 选 择 Unsigned ,表示 输入 数据 记录 时 对 应 字段 的 值 只 能 是 大 于 或 等 于 0 的 数 。 


3. 前 导 0( ZeroFill) 


在 图 3-13 的 “属性 " 列 中 ,对 某 个 字段 选择 Unsigned ZeroFill ,表示 在 输入 数据 记录 时 
对 应 字段 的 值 达 不 到 规定 的 长 度 时 ,自动 左 侧 补 0 占 位 。 例 如 , 班 内 序号 TinyInt Unsigned 
Zerofil ,由 于 无 符号 的 TinyInt 类 型 默认 长 度 为 3, 因 此 ,在 输入 班 内 序号 值 时 ,如 果 输 入 
1, 则 填写 001 ;如果 输入 15 , 则 填写 015 等 。 

4. 默认 值 (Default) 


默认 值 也 称 初 值 , 即 在 增加 数据 记录 时 ,由 系统 自动 填写 到 字段 的 值 。 对 二 进 制 大 对 
象 型 (BLOB) 和 文本 型 (Text) 字 段 不 能 设置 默认 值 ;对 数值 字符 串 .日 期 及 时 间 型 字段 均 
可 在 图 3-13 的 “默认 ” 列 中 选择 “定义 "并 设置 默认 值 (如 100) 。 例 如 ,在 公司 表 中 增加 数 
据 记录 时 ,系统 自动 将 100 填写 到 注册 人 数字 段 ,作为 初始 值 。 


5. 自 增值 ( Auto_Increment) 
数据 表 中 的 自 增值 字段 是 指向 数据 表 中 增加 数据 记录 时 ,如 果 不 添加 该 类 字段 的 值 ， 
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则 系统 用 本 数据 表 中 “ 自 增值 字段 曾经 最 大 值 ”( 建 数据 表 后 的 初 值 为 0) 加 1 后 填写 新 记 
录 该 字段 。 一 个 数据 表 可 以 有 一 个 或 没有 自 增值 字段 , 自 增值 字段 必须 是 数值 型 ,并 且 为 
主键 。 一 般 在 难于 确定 主 属性 的 数据 表 中 增加 一 个 记载 记录 序号 的 字段 ,以 便 设置 主键 。 

选中 (VV) 图 3-13 的 A_I(Auto_Increment 的 缩写 ) 列 ,将 当前 字段 设 为 自 增值 字段 ,并 
自动 设置 为 主键 。 一 个 数据 表 中 的 A_I 列 ,最 多 只 能 选中 一 个 字段 。 

所 谓 “ 自 增值 字段 曾经 最 大 值 "是 指 自 创建 数 据 表 以 来 ,到 增加 记录 时 为 止 ,数据 表 
中 自 增值 字段 存储 过 的 最 高 值 。 伴 随 着 数据 记录 的 删除 或 修改 ,在 新 增加 记录 时 ,“ 自 增 
值 字段 曾经 最 大 值 " 的 数据 记录 可 能 已 经 不 存在 ,但 其 最 大 值 仍然 有 效 。 

【 例 3.16】 创建 论坛 表 , 包 含 4 个 字段 : 文章 序号 Int( 选 中 图 3-13 的 A_I 列 ) ,作者 
VarChar(20 ) ,文章 内 容 Text 和 更 新 时 间 TimeStamp( 时 间 戳 ) 。 

随后 向 数据 表 中 增加 3 个 记录 ,人 工 填写 作者 和 文章 内 容 , 而 不 填 文章 序号 和 更 新 时 
间 , 则 系统 填写 这 3 个 记录 的 文章 序号 分 别 为 1.2 和 3, 更 新 时 间 为 增加 记录 当时 的 系统 
日 期 和 时 间 。 将 第 3 个 记录 删除 后 ,再 用 同样 的 方法 新 增加 1 个 记录 (此 时 文章 序号 曾经 
最 大 值 仍然 为 3) ,系统 填写 文章 序号 为 4( 并 不 是 3) 。 再 将 第 2 个 记录 的 文章 序号 改 为 
10 , 则 其 更 新 时 间 自 动 变 为 修改 数据 时 的 系统 日 期 和 时 间 , 再 用 上 述 方法 增加 1 个 记录 
(此 时 文章 序号 曾经 最 大 值 为 10) , 则 新 记录 的 文章 序号 为 11。 


6. 数据 表 的 主键 


在 MySQL 数据 库 中 , 某 些 数据 表 可 以 不 设 主键 ,但 为 了 避免 重复 存储 数据 记录 ,大 多 
数 数据 表 都 设置 主键 (Primary ,也 称 主 索引 ) 。 数 据 表 可 有 一 个 主键 ,主键 可 能 由 一 个 或 
多 个 主 属性 (字段 ) 构 成 ,系统 定义 键 名 ( 即 索引 名 称 ) 为 Primary。 除 确保 不 重复 存储 数 
据 记录 外 , 主键 还 能 控制 输出 数据 记录 的 初始 顺序 ( 按 主键 值 排序 ) 。 

在 图 3-13 中 ,由 “索引 ” 列 选 为 PRIMARY 的 各 个 字段 ( 主 属性 ) 构 成 了 主 索引 关键 
字 。 单 击 “ 保 存 " 按 钮 后 便 设置 了 数据 表 的 主键 。 例 如 ,创建 公司 表 时 ,选择 公司 名 称 行 
的 “索引 ? 列 为 PRIMARY ;在 创建 GWCJB 时 ,选择 岗位 编号 和 身份 证 号 两 行 的 “索引 ” 列 
均 为 PRIMARY , 即 主键 为 : (岗位 编号 ,身份 证 号 ) 。 

7. 数据 表 的 关键 字 

当 一 个 数据 表 中 有 两 个 或 更 多 关键 字 时 ,可 以 将 一 个 关键 字 设 置 为 主 索引 ,其 他 关键 
字 设 置 为 唯一 索引 (Unique) , 即 关键 字 索 引 。 唯 一 索引 同样 起 着 避免 数据 记录 重复 存储 
的 作用 。 在 图 3-13 中 ,索引 ”" 列 选 为 Unique 的 各 个 字段 ( 主 属性 ) 构 成 了 唯一 索引 的 关 
键 字 ,系统 定义 键 名 为 所 选 的 第 一 个 字段 名 。 

8. 数据 表 的 普通 索引 

数据 表 的 普通 索引 关键 字 的 值 可 以 重复 ,主要 用 于 与 其 他 数据 表 创 建 关 联 及 参照 完 
整 性 。 在 图 3-13 中 ,索引 ? 列 选 为 Index 的 各 个 字段 构成 了 一 个 普通 索引 的 关键 字 , 系 
统 定义 键 名 也 为 所 选 的 第 一 个 字段 名 。 例 如 ,创建 岗位 表 (GWB) 时 ,一 般 将 “公司 名 称 ” 
字段 的 “索引 ” 列 选 为 Index。 
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3.7 维护 数据 表 


维护 数据 表 主 要 包括 修改 数据 表 结 构 ,设置 主键 及 相关 索引 、 删 除数 据 表 、 重 命名 数 
据 表 ,移动 数据 表 ,复制 数据 表 和 设置 数据 表 间 的 关联 等 操作 。 


3.7.1 维护 数据 表 结 构 及 相关 索引 


在 当前 数据 库 信息 窗口 中 (如 图 3-12 所 示 ) , 单 击 数据 表 名 (如 gwb) 所 在 行 的 “ 结 
构 " 按 钮 ,或 者 , 单 击 数据 表 名 (如 gwb, 选 为 当前 数据 表 ) 一 “结构 "选项 卡 ,在 图 3-14 中 对 
数据 表 结 构 及 其 相关 索引 进行 维护 。 操 作 数据 表 结 构 的 用 户 必须 具有 Select 和 Alter 两 
种 权限 。 


选择 字段 列 所 在 行 字段 的 操作 工具 













浏览 MI 结构 局 SQL 对 搜索 有 插入 加 导出 局 导入 少 操 作 名 追踪 | v 更 多 
类 型 整理 属性 空 默认 额外 操作 
char(5) utf8_general_ci 否 无 多 修改 @ 删除 v 更 多 
varchar(30) utf8_general_ci 寺 必修 改 © 删除 > 更 多 
enum('1'. 2. '3,, 4'. '5') utfB_general_ci 是 3 只 修改 @ 删除 v 更 多 
enum(1 223 .455) utf8_general_ci 是 2 必修 改 日 划 除 > 更 多 
tinyint(3) Un 是 1 成 修改 @ 删除 v 更 多 
tinyint(2) aa | e7 修改 日 删除 > 更 多 












tinyint(3) Daom 是 0 

date 是 NULL 叶 修 改 @ 删除 Y 更 多 

tinytext ut8_general_ci 是 NULL e7 修 改 日 删除 ~ 更 多 

可 |11 公司 名 4 0) it JULL 修改 日 齐 除 > 更: 
ET ET TT TT 
忆 打印 预览 唱 关系 查看 遇 规划 表 结 构 德 ” 蛙 追踪 表 

驶 添加 [1 | 个 字段 @ 于 表 结尾 © 于 表 开 头 @ 于 之 后 [岗位 编号 国 区 7] 


索引 及 国 索引 加 
其 换 作 慌 | 损人 刍 各 类型， 叭 一 此 内 字 用 基数 整理 空 注 和 
志 编 辑 加 删除 PRIMARY BTREE 是 和 否 岗位 编号 2 A 否 

岗位 名 称 2 A 和 理 
wu 编辑 © 删除 公司 名 称 BTREE 否 否 公司 名 称 2 A 是 























图 3-14 ”当前 数据 表 的 “结构 "选项 卡 


1. 增加 新 字段 


在 图 3-14 中 的 “添加 ” 框 输入 新 增 字 段 的 个 数 ,选择 新 增 字 段 的 位 置 (于 表 结尾 .于 
表 开头 或 于 之 后 ) , 单 击 * 执 行 "按钮 ,在 “数据 表 结 构 " 窗 口中 (与 图 3-13 类 似 ) 输入 新 字 
段 名 称 和 数据 类 型 等 信息 。 
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2. 修改 字段 信息 


字段 信息 包括 字段 名 ,数据 类 型 和 长 度 等 内 容 。 进 行 如 下 操作 可 以 修改 字段 信息 : 

(1) 修改 一 个 字段 信息 : 单 击 字段 名 所 在 行 的 “修改 "按钮 。 

(2) 修改 多 个 字段 信息 : 在 “选择 字段 列 " 中 选中 (V ) 字 段 或 单 击 “ 全 选 " 按 钮 , 单 击 
选中 的 字段 操作 “修改 "按钮 。 

在 上 述 操 作 中 , 单 击 “ 修 改 " 按 钮 后 均 在 “数据 表 结 构 " 窗 口中 (与 图 3-13 类 似 ) 修改 
字段 名 称 和 数据 类 型 等 信息 。 


3. 删除 字段 


在 删除 字段 时 ,一 个 数据 表 中 至 少 要 保留 一 个 字段 。 

(1) 删除 一 个 字段: 单 击 字段 名 所 在 行 的 “删除 "一 ~ 确定 "按钮 。 

(2) 删除 多 个 字段 : 在 “选择 字段 列 " 中 选中 ( V ) 字 段 或 单 击 * 全 选 "按钮 后 再 反选 ， 
单 击 选 中 的 字段 操作 中 的 “删除 "一 “是 "按钮 。 


4. 设置 主键 及 相关 索引 


在 “选择 字段 列 " 中 ,选中 ( V ) 相关 字段 (如 GWCJB 中 的 岗位 编号 和 身份 证 号 ) , 单 
击 * 主 键 "按钮 ,用 选中 的 字段 创建 主键 ( 主 关键 字 ) 索 引 , 键 名 为 Primary; 单 击 “ 唯 一 " 按 
钮 ,用 选中 的 字段 创建 关键 字 索 引 , 键 名 为 选中 的 第 一 个 字段 名 ; 单 击 “索引 ”按钮 ,用 选 
中 的 字段 创建 普通 索引 (Index) , 键 名 也 为 选中 的 第 一 个 字段 名 。 


5. 管理 索引 


在 当前 数据 表 的 “结构 "选项 卡 中 ( 如 图 3-14 所 示 ) , 单 击 索 引 前 的 ”+ "按钮 ,展开 索 
引 及 其 操作 框 ,可 以 单 击 索引 行 的 “编辑 ”按钮 ,修改 键 名 (索引 名 称 ) 和 索引 类 型 ; 单 击 
“删除 "按钮 ,将 删除 对 应 的 索引 。 


3.7.2 数据 表 操 作 


数据 表 操 作 是 指 对 数据 表 结 构 和 数据 记录 同时 进行 的 操作 , 即 对 数据 表 整 体 进行 操 
作 。 如 删除 .复制 .移动 和 更 名 数据 表 等 操作 。 

在 当前 数据 库 ( 如 RCZP) 信息 窗口 (如 图 3-12 所 示 ) 中 ,可 以 删除 数据 表 ; 进一步 单 
击 数据 表 名 ( 如 gwb, 选 为 当前 数据 表 ) 一 “操作 ”选项 卡 ,可 以 对 当前 数据 表 进 行 复制 移 


动 和 更 名 等 操作 。 

1. 删除 数据 表 

有 Drop 权限 的 用 户 ,在 图 3-12 中 , 单 击 数据 表 名 所 在 行 的 “删除 "一 “确定 "按钮 ,可 
以 删除 数据 表 。 
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2. 复制 数据 表 


复制 数据 表 的 用 户 必 须 有 Select 和 Create 权限 ,如 果 还 复制 数据 记录 ,也 需要 有 
Insert 权限 。 

在 “操作 ”选项 卡 的 “将 数据 表 复制 到 "信息 框 (如 图 3-15 所 示 ) 中 ,选择 目标 数据 库 
名 (如 也 ) 和 输入 目标 数据 表 名 ( 如 岗位 表 ) ,再 目标 数据 库 名 目标 数据 表 名 
选中 相关 选项 ,最 后 单 击 “ 执 行 "按钮 。 目 标 数 
据 表 与 源 数 据 表 可 以 在 不 同 的 数据 库 中 ,也 可 以 
有 不 同 的 数据 表 名 ,执行 "结果 对 源 数据 库 及 
数据 表 没 有 任何 影响 ,在 目标 表 中 仍然 保留 各 类 
索引 。 常 用 选项 的 含义 如 下 : 

(1) 仅 结构 : 复制 数据 表 结 构 信息 (包括 主 
键 ) ,但 不 包含 数据 记录 , 即 , 仅 产生 空 目 标 数 
据 表 。 

(2) 结构 和 数据 : 目标 数据 表 与 原 数据 表 ”图 3-15 “将 数据 表 复制 到 "信息 框 
内 容 完 全 一 致 , 即 包括 数据 表 中 完整 的 结构 信息 
和 数据 记录 。 


3. 移动 数据 表 


移动 数据 表 的 用 户 必须 有 Select Insert Create .Drop 和 Alter 权限 。 在 “操作 ”选项 卡 
的 “将 数据 表 移 动 到 "信息 框 (与 图 3-15 相似 ) 中 ,操作 方法 也 与 复制 数据 表 基 本 相同 , 结 
果 只 是 从 源 数 据 库 中 删除 了 数据 表 。 


4. 数据 表 更 名 


数据 表 更 名 与 数据 表 移 动 的 用 户 权 限 要 求 相 同 , 在 “操作 ”选项 卡 的 “ 表 选 项 "信息 框 
中 ,输入 修改 后 的 数据 表 名 , 单 击 “ 执 行 " 按 钮 即 可 实现 数据 表 更 名 。 数 据 表 更 名 只 能 在 
同一 个 数据 库 中 进行 ,因此 ,不 需要 选择 数据 库 。 


3.7.3 数据 表 间 关联 及 参照 完整 性 


在 一 个 数据 库 中 ,大 多 数 数据 表 之 间 都 有 直接 或 间接 的 关系 ,通常 将 这 种 关系 称 为 关 
联 。 在 MySQL 数据 库 中 ,将 关联 的 数据 表 之 间 没 有 约束 条 件 的 关联 称 为 内 关联 (简称 内 
联 ) ,将 有 约束 条 件 的 关联 称 为 外 键 约束 关联 。 


1. 创建 数据 表 间 关 联 及 参照 完整 性 的 操作 


GWB 中 的 公司 名 称 字 段 与 公司 表 的 关键 字 公 司 名 称 含义 相同 ,因此 ,公司 名 称 字段 
是 GWB 的 外 键 。 同 样 ,身份 证 号 是 YPRYB 的 关键 字 , 岗 位 编号 是 GWB 的 关键 字 , 即 身 
份 证 号 和 岗位 编号 是 GWCJB 的 两 个 外 键 。 创 建 数据 表 间 关联 操作 的 用 户 必须 有 Select 
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据 表 复制 到 (数据 库 条 数据 表 各 ): 





























口 添加 DROP TABLE 
口 添加 自 增 (AUTO_INCREMENT) 值 
口 切换 到 复制 的 数据 表 








全 


和 Alter 权限 。 

数据 表 的 外 键 主要 用 于 与 父 表 建 立 关联 。 因 此 ,创建 数据 表 间 关联 前 , 父 表 应 该 已 经 
存在 并 创建 了 相关 索引 ( 主 索引 、 唯 一 索引 或 普通 索引 ) 。 通 常 以 具有 外 键 的 数据 表 ( 也 
称 子 表 ,如 GWB 或 GWCJB) 为 当前 数据 表 , 单 击 其 “结构 "选项 卡 中 (如 图 3-14 所 示 ) 的 
“关系 查看 "按钮 ,在 图 3-16 中 创建 数据 表 间 内 联 和 外 键 约束 关联 。 


内 联 关键 字 ， 父 表 ”外 键 约束 关键 字 ， ”外 键 约束 (参照 
的 关键 字段 父 表 的 索引 字段 。 完整 性 ) 规 则 


















































关系 

字段 内 联 日 ha (INNODB) 

身份 证 图 [rczp ypryb -身份 证 号 ”加 ON DELETE [CASCADE 国 
得 ON UPDATE [CASCADE | 

区 图 | rczp “gwb 岗位 编号 ON DELETE [RESTRICT 图 



































图 3-16 创建 GWCJB 与 其 父 表 之 间 关 联 的 信息 框 


(1) 创建 内 联 的 操作 : 在 图 3-16 中 ,从 子 表 外 键 行 (如 身份 证 号 或 岗位 编号 ) 的 “内 
联 " 下 拉 列 表 框 中 ,选择 父 表 中 的 关键 字 ( 主 索引 或 唯一 索引 字段 ,如 ypryb. 身份 证 号 或 
gwb. 岗位 编号 ) ,但 不 能 用 普通 索引 字段 。 最 后 单 击 * 保 存 " 按 钮 即 创建 内 联 。 

(2) 创建 外 键 约束 关联 的 操作 : 在 图 3-16 中 ,从 子 表 中 外 键 行 (必须 为 主 属性 或 索 
引 字段 ,如 身份 证 号 或 岗位 编号 ) 的 “外 键 约束 "下 拉 列 表 框 中 ,选择 父 表 中 索引 字段 ( 主 
索引 ,唯一 索引 或 普通 索引 ,如 ypryb. 身份 证 号 或 gwb. 岗位 编号 ) 。 由 于 外 键 约束 关联 对 
关联 数据 表 的 操作 有 约束 条 件 , 因 此 ,还 要 进一步 选择 外 键 约束 (参照 完整 性 ) 规则 ,系统 
默认 约束 规则 均 为 RESTRICT( 限制)。 最 后 单 击 “ 保 存 "按钮 。 

由 于 内 联 对 关联 数据 表 的 操作 没有 任何 限制 ,仅仅 表示 数据 表 之 间 的 关系 ,因此 , 实 
际 应 用 中 ,很 少 用 这 种 关联 ,而 外 键 约束 关联 比较 常用 。 

创建 数据 表 之 间 的 关联 后 ,在 当前 数据 库 信 息 窗口 (如 图 3-12 所 示 ) 中 , 单 击 “ 更 多 ”一 
“设计 器 "选项 ,将 显示 当前 数据 库 中 数据 表 之 间 的 关联 如 图 3-17 所 示 , 连 线 较 粗 的 一 端 
表示 子 表 及 其 外 键 ,也 表示 子 表 与 父 表 中 的 数据 记录 是 多 对 一 的 关系 。 


2. 删除 数据 记录 的 约束 规则 


外 键 约束 关联 对 增加 、 更 新 和 删除 数据 记录 以 及 删除 数据 表 的 操作 都 有 某 种 制约 作 
用 。 删 除数 据 记录 的 约束 规则 ( On Delete) 是 指 删除 父 表 中 的 数据 记录 时 应 该 遵循 的 规 
则 。 有 如 下 规则 : 
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主 身 份 证 号 : char(18) 站 岗位 编号 : char(5) 


















旧 姓 名 : varchar(10) | \ 大 SEEEESwsibg | (a ws : varchar(0) 
拓 婚 否 :tinyint(1) | 人， 身份 证 号 : char(18) 详 最 低 学 历 : enum(1.2.3.4.5)) 
全 最 后 学 历 : enum(12.3.4.5) | 让 岗位 编号 - char(5) 章 最 低 学 位 : enum('1.2.3.459 
全 最 后 学 位 : enum('1.2.3,4.5)| | 大 资格 审核 tinyint(1) 雪人 数 tinyint(3) unsigned 
下 所 学 专业 : varchar(30) 类 笔试 成 绩 : tinyint(3) unsigned 闫 年 龄 上 限 :tinyint(2) unsigned 
日 通信 地 址 : varchar(50) | 于 面试 成 绩 tinyint(3) unsigned | | 六 年 新 : mediumint(8) 
日 邮政 编码 ; char(6) | 亲笔 试 成 绩 比 例 tinyint(3) unsigned 
下 Emai 账 号 ; yarchar(30) 日 笔试 日 期 : date 
日 QQ 账号 : varchar(30) | 1 公司 名 称 : varchar(40) 下 聘任 要 求 : tinytext 
下 固定 电话 ;varchar(20) 日 地 址 :varchar(50) 目 公 司 名 称 : varchar(40) 
本 移动 电话 : varchar(15) | 加 注册 日 期 . date 
日 密码 ;varchar(10) 莫 注 册 人 数 : smallint(5) unsigned | | * 文章 序号 : int(11) 
日 个 人 简历 :text | “| 昌 简介 .text 站 作者 : varchar(20) 

日 邮政 编码 : char(6) 目 内 容 :text 

中 注销 tinyint(1) 加 更 新 时 间 : timestamp 

名 宣传 片 : longblob 目 EMAIL 地 址 : varchar(30) 





图 3-17 ”当前 数据 库 中 表 之 间 的 关联 


(1) Cascade( 级 联 ) : 删除 父 表 ( 如 YPRYB) 中 的 数据 记录 时 ,系统 自动 删除 子 表 ( 如 
GWCJB) 中 相关 联 的 记录 。 所 谓 关 联 记 录 就 是 子 表 外 键 与 父 表 中 关联 字段 值 相等 的 记 
录 。 例 如 ,在 YPRYB 表 中 删除 身份 证 号 为 229901199503121538 的 记录 时 ,系统 自动 删除 
GWCJB 表 中 身份 证 号 为 229901199503121538 的 全 部 记录 。 

(2) No Action 或 Restrict( 限制 ) : 不 能 删除 与 子 表 中 记录 存在 关联 的 父 表 中 的 记录 。 
也 就 是 说 ,删除 父 表 中 记录 的 条 件 是 子 表 中 一 定 没有 与 之 相关 联 的 记录 。 例 如 ,如 果子 表 
GWCJB 中 有 岗位 编号 为 A0001 的 记录 , 则 父 表 GWB 中 不 能 删除 岗位 编号 A0001 的 
记录 。 

(3) Set Null( 置 空 ) : 删除 父 表 中 记录 时 ,系统 自动 将 子 表 中 关联 记录 外 键 字段 的 值 
填 成 Null。 这 就 要 求 设计 子 表 时 ,外 键 字段 必须 允许 Null( 空 ,选中 图 3-13 的 “ 空 " 列 )。 


3. 更 新 (修改 ) 数 据 记录 的 约束 规则 


更 新 (修改 ) 数 据 记 录 的 约束 规则 ( On Update ) 是 指 修改 父 表 中 的 数据 记录 时 ,系统 
应 该 遵循 的 规则 。 有 如 下 规则 : 

(1) Cascade( 级 联 ) : 修改 父 表 ( 如 YPRYB) 中 关联 字段 (如 身份 证 号 ) 的 值 时 ,系统 自 
动 更 新 子 表 中 (如 GWCJB ) 关 联 记录 外 键 字段 的 值 (如 身份 证 号 ) ,以 便 保 证 数据 的 一 致 性 。 
例如 ,在 YPRYB 表 中 ,将 身份 证 号 由 229901199503121538 改 为 22990119950312153X 时 , 系 
统 自动 将 GWCJB 表 中 与 其 关联 的 所 有 记录 身份 证 号 均 改 为 22990119950312153X。 

(2) No Action 或 Restrict( 限制 ) : 对 子 表 中 存在 关联 记录 的 父 表 记录 ,不 能 修改 其 关 
联 字段 的 值 。 例 如 ,如 果子 表 GWCJB 中 有 岗位 编号 (外 键 ) 为 A0001 的 记录 , 则 不 能 将 父 
表 GWB 中 岗位 编号 (关联 字段 ) A0001 改 成 其 他 值 。 
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(3) Set Null( 置 空 ) : 修改 父 表 中 关联 字段 的 值 时 ,自动 将 子 表 中 关联 记录 的 外 键 字 
段 值 填 成 Null( 此 字段 必须 允许 Null) 。 

设计 数据 库 时 ,可 以 选择 数据 表 之 间 不 创建 关联 、 创 建 内 联 或 仅 创建 外 键 约束 关联 。 
创建 外 键 约束 关联 时 ,一 定 要 设置 约束 规则 ,系统 默认 的 约束 规则 是 Restrict( 限制 ) 。 

在 MySQL 中 ,定义 删除 和 更 新 记录 的 约束 规则 ,从 表面 上 看 ,只 规定 了 删除 和 更 新 父 
表 中 记录 时 的 限制 或 连锁 反应 ,实质 上 对 子 表 中 增加 、 修 改 记 录 也 有 约束 作用 。 例 如 ,不 
允许 在 子 表 中 增加 与 父 表 无 关联 的 记录 ,也 不 许 将 子 表 中 的 记录 修改 成 与 父 表 无 关联 的 
记录 。 

对 设置 外 键 约束 关联 的 数据 表 进 行 操作 时 ,操作 顺序 有 些 限 制 。 例 如 ,要 先 创 建 父 数 
据 表 ,再 以 子 表 为 当前 数据 表 设 计 关 联 ;删除 数据 表 时 , 先 删 除 子 表 , 后 删除 父 表 ;在 向 数 
据 表 中 输入 数据 记录 时 , 先 输入 父 表 中 的 记录 ,后 输入 子 表 中 的 关联 记录 。 

当 约 束 规则 为 限制 (No Action 或 Restrict) 时 ,应 该 先 删除 子 表 中 的 记录 ,才能 删除 父 
表 中 的 关联 记录 ;修改 关联 字段 值 时 ,将 变 得 更 复杂 。 因 此 ,多 数 数据 表 之 间 的 约束 规则 
都 采用 级 联 (Cascade) 规则 。 


3.8 维护 数据 表 中 的 数据 


创建 数据 表 的 主要 目的 是 在 数据 表 中 存储 数据 ,因此 ,数据 记录 是 数据 表 中 的 核心 内 
容 , 通 常 将 不 含 任何 数据 记录 的 数据 表 称 为 空 数据 表 。 维 护 数 据 表 中 的 数据 主要 包括 输 
入 (也 称 插入 或 增加 ) ,修改 (也 称 更 新 ) 和 删除 数据 记录 等 操作 。 


1. 插入 数据 记录 


向 数据 表 中 插 和 人 数据 记录 操作 的 用 户 必 须 有 Select 和 Insert 权限 。 在 当前 数据 库 
信息 窗口 (如 图 3-12 所 示 ) 中 , 单 击 数据 表 名 (如 gwcjb) ,再 单 击 “ 插 入 "选项 ,在 “ 插 
入 "选项 卡 (如 图 3-18 所 示 ) 的 “ 值 " 列 中 ,选择 (如 身份 证 号 .岗位 编号 字段 ) 或 输入 对 
应 字段 的 值 。 


字段 。 类 型 空 值 

身份 证 号 char(18) ~ 11980119921001132X 国 
岗位 编号 char(5) | A0001 国 
资格 审核 tinyint(T) 国 1 



































笔试 成 绩 tinyint(3) unsigned | 75 



































面试 成 绩 tinyint(3) unsigned 1 90 


四 








图 3-18 “插入 "数据 记录 选项 卡 


在 输入 二 进 制 大 对 象 (BLOB ) 型 的 字段 (如 公司 表 中 的 宣传 片 ) 数据 时 ,应 该 单 击 对 
应 行 的 “浏览 "按钮 ,以便 选择 对 应 的 文件 ,将 文件 内 容 转 存 到 数据 表 中 。 
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每 输入 一 个 记录 都 要 单 击 对 应 的 “执行 "按钮 ,以 便 保 存 数据 。 在 输入 关联 数据 表 中 
的 数据 记录 时 ,要 先 输入 父 表 中 的 记录 (如 YPRYB 中 的 身份 证 号 11980119921001132X 
和 GWB 中 的 岗位 编号 A0001 ) ,才能 输入 子 表 中 的 数据 记录 。 


2. 浏览 与 编辑 数据 记录 


编辑 ( 修改) 数据 记录 操作 的 用 户 必 须 有 Select 和 Update 权限 。 在 当前 数据 库 信息 
窗口 (如 图 3-12 所 示 ) 中 , 单 击 数据 表 名 ( 如 gwcjb) ,再 单 击 “ 浏 览 " 选 项 进入 "浏览 "选项 
卡 , 如 图 3-19 所 示 。 
选择 记录 列 a 
| 




















IC 忌 身份 证 号 岗位 编号 资格 审核 笔试 成 绩 面试 成 绩 
口 | 编辑 了 怠 复制 @ 删除 |11980119921001132X | A0001 1 75 90| 
口 | 上 编辑 于 复制 @@ 删除 |11980119921001132X B0001 1 85 | 
口 || 忆 编辑 张 复制 @ 删除 |11980119921001132X | B0002 1 90 65| 
口外 .> 编辑 防 复制 @@ 删除 |219901199001011351 A0002 0 70 | 
口 | 编辑 怠 复制 @ 删除 |219901199001011351 | B0001 0 75 60| 
口 | .编辑 复制 © 删除 |219901199001011351 B0002 1 89 8| 
口 | 编辑 张 复 制 @ 删除 |229901199305011575 | A0001 0 90 75| 
口 || .编辑 3 复制 加 删除 |229901199305011575 A0002 0 80 65 | 
口 | 编辑 防 复制 @ 删除 | 229901199305011575 | B0001 0 50 go| 
口 || .编辑 3 复制 © 删除 |229901199305011575 B0002 0 75 75 | 
口 | 编辑 卫 复制 目 删 除 | 229901199503121538 | A0002 1 80 85| 
口 || .> 编辑 计 复制 @ 删除 |229901199503121538 B0002 1 90 本 | 





对 选中 的 记录 操作 
图 3-19 “浏览 "数据 记录 选项 卡 


(1) 数据 记录 排序 : 浏览 数据 时 ,系统 初始 按 主 关键 字 ( 如 身份 证 号 相同 时 再 按 岗 位 
编号 排序 ) 的 值 排列 记录 , 单 击 某 列 标题 ( 如 笔试 成 绩 、 面 试 成 绩 等 ) 可 以 重新 升序 或 降序 
排列 记录 。 

(2) 编辑 (修改 ) 数 据 记 录 : 单 击 所 在 行 的 “编辑 "按钮 ,可 以 修改 当前 数据 记录 ; 选 
中 (V ) 若 干 行 后 再 单 击 选 中 的 记录 操作 ”修改 "按钮 ,可 以 修改 多 个 数据 记录 。 修 改 数据 
记录 的 窗口 及 操作 方法 与 图 3-18 的 “插入 "数据 记录 选项 卡 类 似 。 

(3) 打开 二 进 制 大 对 象 ( BLOB ) 型 字段 的 数据 : 从 对 应 列 的 右 击 菜单 中 选择 “在 新 窗 
口中 打开 ”或 “打开 "选项 ,可 以 打开 对 应 的 数据 对 象 , 也 可 以 选择 * 目标 另存 为 选项 ,将 
对 应 的 二 进 制 大 对 象 数据 保存 到 文件 中 。 


3. 删除 数据 记录 


执行 删除 数据 记录 操作 的 用 户 必 须 有 Select 和 Delete 权限 。 在 “浏览 "数据 记录 选项 
卡 ,如 图 3-19 所 示 , 单 击 所 在 行 的 “删除 "按钮 ,可 以 删除 当前 记录 ;选中 (V ) 若 干 行 后 青 
单 击 选中 的 记录 操作 “删除 "按钮 ,可 以 删除 多 个 数据 记录 。 
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3.9 复制 及 导入 导出 数据 库 


由 于 计算 机 软 硬 件 的 故障 病毒 或 人 为 操作 等 因素 影响 ,可 能 导致 丢失 或 破坏 数据 库 
中 的 数据 ,另外 ,也 经 常 需要 将 数据 库 由 一 台 服 务 器 移植 到 另 一 台 服 务 器 ,要 完成 这 些 任 
务 ,都 要 求 对 数据 库 进行 复制 .导入 和 导出 操作 。 


1. 复制 当前 数据 库 的 操作 


复制 数据 库 将 当前 数据 库 中 的 全 部 信息 (包括 数据 表 、 主 键 和 关联 等 ) 复 制 到 当前 服 
务 器 的 男 一 个 数据 库 中 。 执 行 复制 数据 库 操作 的 用 户 必须 有 Select Insert、Create 和 Alter 
权限 。 ”| 。 复制 数据 库 到 : 
在 当前 数据 库 信 息 窗 口 如 图 3-12 所 示 ) RCZPBF| 
中 , 单 击 * 操 作 "选项 卡 , 在 “复制 数据 库 到 " 信 | 9 呈 玖 
息 框 中 ,输入 复制 (备份 ) 后 的 数据 库 名 称 ( 如 © ee Ee, 
RCZPBF ) ,选择 必要 的 选项 ,如 图 3-20 所 示 , 最 口 添加 DROP TABLE/ DROP VIEW 
后 单 击 * 执 行 "按钮 。 中 和 (AUTO_INCREMENT) 值 
除 选中 “复制 前 创建 数据 库 " 项 以 外 ,其 他 A hse 
相关 选项 与 复制 数据 表 ( 如 图 3-15 所 示 ) 的 选 
项 含义 相同 。 


2. 导出 当前 数据 库 的 操作 


导出 数据 库 可 以 将 数据 库 中 的 信息 转 存 
到 其 他 类 型 (如 SQL .PDF 等 ) 的 文件 中 ,以 便 实现 数据 备份 或 移植 到 其 他 服务 器 上 。 

执行 导出 数据 库 操作 的 用 户 只 要 求 有 Select 权限 。 在 当前 数据 库 信息 窗口 (如 图 3-12 
所 示 ) 中 , 单 击 “ 导 出 "选项 卡 , 从 “格式 ”下拉 框 中 选择 文件 类 型 (如 SQL .PDF 等 ) , 单 击 “ 执 
行 " 按 钮 后 , 按 导出 向 导 的 要 求 选择 保存 位 置 及 文件 名 ( 如 RCZP. SQL) 。 

要 导出 当前 服务 器 中 的 所 有 数据 库 , 只 是 在 PHPMyAdmin 主页 中 (如 图 3-2 所 示 ) 单 
击 “ 导 出 ”选项 卡 ,其 他 操作 与 上 述 相同 。 


3. 导入 当前 数据 库 的 操作 


执行 导入 当前 数据 库 操作 的 用 户 必须 有 Insert、Create 和 Alter 权限 。 将 其 他 数据 库 
导出 的 结果 文件 (如 RCZP. SQL) 导 入 到 另 一 个 数据 库 中 ,一般 要 经 历 下 列 步 又 ， 
(1) 在 “数据 库 " 信 息 窗口 中 ,如 图 3-11 所 示 , 创 建 数据 库 ( 可 以 与 原 数据 库 不 同名 
称 , 如 ZP) ,并 将 其 设 为 当前 数据 库 ; 
(2) 在 当前 数据 库 ( 如 ZP) 信 息 窗口 中 (如 图 3-12 所 示 ) , 单 击 “ 导 入 "选项 卡 ; 
(3) 在 “导入 ”选项 卡 中 , 单 击 “ 浏 览 ” 按 钮 ,选择 要 导入 的 文件 名 ( 如 RCZP. SQL) , 字 
符 集 ( 如 utf-8) 和 文件 格式 ( 如 SQL) ,最 后 单 击 “ 执 行 " 按 钮 。 
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| 
图 3-20 “复制 数据 库 到 "信息 框 





如 果 要 将 数据 库 从 一 台 服 务 器 移植 到 另 一 台 服 务 器 上 , 则 要 在 目标 服务 器 上 创建 数 
据 库 (通常 与 原 数据 库 同名 ,如 RCZP) ,并 设 为 当前 数据 库 后 ,再 将 源 服务 器 上 导出 的 文 
件 ( 如 RCZP. SQL) 导 入 到 当前 数据 库 中 即 可 。 

本 章 重点 讲述 了 MySQL 的 简单 语句 和 PHPMyAdmin 可 视 化 平台 的 基本 操作 ,以 及 创 
建 与 管理 用 户 及 数据 库 的 基本 过 程 和 常见 方法 。 事 实 上 ,用 于 管理 用 户 和 数据 库 的 工具 
还 有 很 多 ,它们 功能 类 似 ,目标 一 致 ,只 是 操作 方法 及 灵活 性 方面 有 些 差异 ,各 有 千秋 。 在 
实际 应 用 过 程 中 ,多 数 用 户 更 习惯 借助 可 视 化 平台 ( 如 PHPMyAdmin ) 结 合 SQL 语句 完成 
数据 库 管理 和 数据 统计 分 析 任 务 。 


习 题 


一 、 填空 题 


1. 在 XAMPP 的 控制 台 , 单 击 “QD 按钮 ,进入 MySQL 的 命令 窗口 ;在 命令 窗口 用 

”加 语句 能 登录 数据 库 服 务 器 ;安装 MySQL 系统 后 ,系统 初始 超级 管理 员 用 户 名 为 
@_, 它 具有 MySQL 数据 库 的 全 局 权限 。 执 行 语句 MySQL 登录 数据 库 服务 器 时 ,系统 

默认 用 户 名 为 ”@ ,默认 全 地 址 是 @ 。 

2. 在 MySQL 的 命令 窗口 的 _ 中 “提示 符 下 能 执行 语句 : MySQL [-u< 用 户 名 >] [- 
h < 数据 库 服务 器 IP 地 址 >] [-p[ < 密码 > ] ] ,其 中 @ 中 的 英文 字母 不 区 分 大 小 写 ， 
_ @_ 中 的 英文 字母 区 分 大 小 写 。 连 接 数据 库 服 务 器 成 功 后 ,在 _@_ 提示 符 下 执行 
MySQL 语句 ; 断 开 与 数据 库 服务 器 的 连接 应 该 执行 ”@ ”语句 。 

3. 要 将 MySQL 命令 窗口 的 内 容 送 入 剪贴 板 , 应 该 单 击 窗口 控制 菜单 一 “编辑 ”一 
_@ 选 项 ，@ 鼠标 选 定 内 容 ,再 单 击 控制 菜单 一 “编辑 "一 ”@ 选项 。 

4. 创建 用 户 时 需要 指出 用 户 所 在 的 主机 ,用 _Q@ 表示 本 地 服务 器 ;用 _@@ 表示 
其 他 计算 机 。 

5. 执行 Create User ST 语句 后 ,ST 的 主机 为 “四 ,密码 为 “四 ”。 要 设置 为 当前 服 
务 器 的 用 户 , 应 该 在 ST 后 加 _@_ 项 ;设置 密码 为 st918 应 该 在 语句 中 加 四 短语。 

6. 用 户 需 要 有 某 些 权 限 才 能 操作 数据 库 。 填 写 执行 下 列 操作 的 用 户 应 该 具有 的 权 
限 : 建立 数据 表 _Q@ _ ,修改 数据 表 结 构 _@ ,删除 数据 表 ”@ ,创建 数据 表 之 间 的 
参照 完整 性 四 ,增加 (插入 ) 数 据 记 录 _@ _, 修 改 (编辑 ) 数 据 记录 ”@ ,删除 数据 
记录 人 @ ,执行 Create User 语句 ,通过 PHPMyAdmin 操作 创建 用 户 @ 。 

7. 执行 Grant ……: On < 对 象 范围 > To < 用 户 名 > 语句 时 ,对 当前 数据 库 中 所 有 对 
象 授权 ,对 象 范 围 应 该 写 _Q@_ ;授予 全 局 权限 ,对 象 范围 应 该 写 _@ ;对 数据 库 RCZP 
中 所 有 对 象 授权 ,对 象 范围 应 该 写 _@) ;对 数据 库 RCZP 中 的 表 YPRYB 授权 ,对 象 范围 

8. 安装 XAMPP 后 ,系统 默认 数据 库 文件 夹 是 _Q@ ,创建 数据 库 RCZP 时 ,创建 的 
文件 夹 是 _@”。 为 了 系统 能 正常 处 理 汉字 信息 ,创建 数据 库 时 ,应 该 选择 的 字符 集 ( 整 
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理 ) 有 图 。 

9. 数据 类 型 为 TinyInt 的 字段 ,占用 QD _B 存储 空间 ,系统 默认 能 存储 有 符号 数 的 
范围 是 _@ ,无 符号 数 的 范围 是 @ 。 

10. 2017 年 9 月 18 日 9 点 18 分 30 秒 创建 销售 表 , 其 中 字段 有 : 时 间 TimeStamp; 数 
量 Int, 设 默认 值 为 10。9 点 28 分 6 秒 又 修改 数据 表 中 的 其 他 字段 ,9 点 30 分 10 秒 向 数 
据 表 中 添加 一 条 记录 ,9 点 48 分 20 秒 将 此 记录 的 数量 改 为 15。 在 输入 或 修改 记录 时 ,用 
户 都 没有 修改 数量 和 时 间 值 。 输 入 记录 后 ,时 间 字 段 的 值 为 中 ,数量 字段 的 值 为 
_ @_ ;修改 记录 后 ,时 间 字 段 的 值 为 ”@) ,数量 字段 的 值 为 由 。 

11. 销售 表 中 含 自 增值 字段 序号 ( Int Auto_Increment) ,创建 数据 表 后 立即 输入 一 条 
记录 ,该 记录 的 序号 值 为 “中 ;将 该 记录 序号 字段 值 改 为 10 后 ,再 添加 一 条 记录 ,新 记 
录 的 序号 值 为 _@ ; 清空 销售 表 中 的 数据 记录 ,再 添加 一 条 记录 ,新 记录 的 序号 值 
为 加 。 

12. 在 MySQL 数据 库 中 ,数据 表 之 间 没 有 约束 条 件 的 关联 称 为 “中 ,有 约束 条 件 
的 关联 称 为 ”@ ,要 设计 数据 表 之 间 的 参照 完整 性 ,应 该 创建 _@ 关联 。 














二 、 单 选 题 
1. 安装 MySQL 系统 后 ,系统 初始 超级 管理 员 用 户 名 为 ( )。 
A. Root B. root C. Admin D. Administrator 
2. 在 命令 提示 符 为 “#" 下 ,执行 ( ) 语 句 能 以 root 身份 登录 本 地 数据 库 服 务 器 。 
A. MySQL -Uroot -h127.0.0.1 B. MySQL -uRoot -h127.0.0.1 
C. MySQL -uroot -h127.0.0.1 D. MySQL -uroot -H127.0.0.1 


3. 将 记事 本 或 PHPMyAdmin 软件 中 的 内 容 送 入 剪贴 板 后 ,要 插入 到 MySQL 命令 窗 
口 光标 位 置 ,应 该 如 何 操作 ( 久 
A. 按 Cul+C 键 
B. 按 Cul+YV 键 
C. 单 击 MySQL 命令 窗口 控制 菜单 一 “编辑 "一 “粘贴 "选项 
D. 单 击 MySQL 命令 窗口 控制 菜单 一 “编辑 "一 “复制 "选项 
4. 与 MySQL 命令 窗口 比较 ,PHPMyAdmin 可 视 化 窗口 的 主要 优点 在 于 ( )。 


A. 输入 编辑 MySQL 语句 B. 执行 MySQL 语句 

C. 生成 MySQL 语句 D. 查看 MySQL 语句 
5. 在 MySQL 中 ,用 ( ) 符号 表示 一 条 语句 结束 。 

A. 逗号 ” ,” B; 分 号 “;” C. 圆 点 “.” D. 句号 “。” 
6. 在 图 34 中 添加 用 户 时 ,( ) 中 的 英文 字母 不 区 分 大 小 写 。 

A. 用 户 名 B. 主机 名 ( LocalHost) 

C. 密码 D. 重新 输入 


7. 下 列 叙 述 中 ,正确 的 是 (  )。 
A. 只 能 对 已 存在 的 数据 库 授 权 
B. 对 不 存在 的 数据 库 授权 会 自动 创建 数据 库 
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C. 对 不 存在 的 数据 库 不 能 授权 
D. 对 已 存在 或 不 存在 的 数据 库 均 可 授权 
8. 用 户 权限 的 对 象 范围 分 全 局 数据 库 和 数据 表 等 ,正确 的 是 ( )。 
A. 为 某 用 户 授予 全 局 权限 ,还 必须 授予 其 数据 库 的 相同 权限 
B. 为 某 用 户 授予 全 局 权限 ,不必 再 授予 其 数据 库 的 相同 权限 
C. 为 某 用 户 授予 某 些 全 局 权限 ,不 能 再 为 其 授予 数据 库 的 其 他 权限 
D. 数据 库 权 限 只 能 操作 数据 库 ,不 能 操作 其 他 对 象 
9. 一 个 MySQL 数据 库 对 应 一 个 (。”)。 
A. 网 站 B. 客户 机 6 文件 炎 忠文 件 
10. 数据 表 中 字段 为 ( 。 ) 数 据 类 型 ,增加 或 修改 数据 记录 时 ,系统 时 间 能 自动 填 人 
对 应 字段 。 
A. Date B. Time C. DateTime D. TimeStamp 
11. 从 节省 空间 的 角度 考虑 ,在 设计 存储 不 定 长 数据 的 字段 时 (如 专业 名 称 、 公 司 名 
称 等 ) ,应 该 选择 ( ) 数 据 类 型 。 
A. Char B. VarChar C. TinyText D. Text 
12. 对 数据 表 中 字段 默认 值 的 正确 叙述 是 ( Ns 
A. 一 个 数据 表 中 只 能 为 一 个 字段 设 默认 值 
B. 创建 数据 表 时 为 记录 填写 默认 值 
C. 修改 记录 时 为 字段 填写 值 
D. 增加 记录 时 系统 自动 填 字段 的 默认 值 
13. 删除 父 表 中 记录 的 同时 删除 子 表 中 的 相关 记录 ,删除 记录 的 约束 规则 应 该 为 
(_ 中 ) ;不 许 删 除 与 子 表 中 记录 有 关联 的 父 表 中 记录 ,删除 记录 的 约束 规则 应 该 为 
(加 ) ; 子 表 中 关联 记录 外 键 字段 值 随 父 表 中 关联 字段 值 而 变化 ,更 新 记录 的 约束 规 
则 应 该 为 ( _@ _) ;不 允许 修改 与 子 表 有 关联 的 父 表 中 记录 的 关联 字段 值 ,更 新 记录 的 


约束 规则 应 该 为 (_@_)。 





A. Cascade( 级 联 ) B. Restrict( 限制 ) 
C. Set Null( 置 空 ) D. 内 联 

14. ( ”) 是 空 数据 表 。 
A. 无 结构 的 数据 表 B. 无 记录 的 数据 表 
C. 无 关键 字 的 数据 表 D. 无 索引 的 数据 表 


15. 在 “浏览 "数据 记录 选项 卡 , 单 击 ( 。 ”) 能 对 数据 记录 进行 排序 。 

A. 编辑 按钮 B. 复制 按钮 C. 修改 按钮 D. 表 的 列 标题 
16. 要 将 数据 库 从 一 台 服 务 器 移植 到 另 一 台 服 务 器 ,最 好 选择 ( 。 ”) 操 作 。 
A. 复制 数据 库 ” B. 复制 数据 表 C. 导出 数据 库 D. 导出 数据 表 
、 多 选 题 
1. 在 命令 提示 符 为 “#" 下 ,执行 ( 。 ”) 语 句 能 以 root 身份 登录 本 地 数据 库 服务 器 。 
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A. MySQL -Uroot -hl127.0.0.1 B. MySQL -uRoot -h127.0.0.1 
C. MySQL D. MySQL -uroot -h127.0.0.1 
E. MySQL -uroot -H127.0.0.1 

2. 在 MySQL 命令 窗口 中 ,执行 ( ) 语 句 能 断 开 数 据 库 服 务 器 的 连接 。 


A. Quit B. Bye C. Disconnect 
D. Exit E. Close 
3. 半角 圆 点 “.” 除 作为 数值 型 数据 中 的 小 数 点 外 ,还 可 作为 ( ) 之 间 的 分 隔 
符号 。 
A. 日 期 型 数据 中 年 月 日 B. 时 间 型 时 分 秒 
C. 数据 库 名 与 数据 源 名 D. 数据 源 名 与 字段 名 
E. 用 户 名 与 密码 
4. 通常 将 ( 。  ) 常 数 用 单 引号 ” "或 双 引 号 "" "引起 来 。 
A. 日 期 型 B. 日 期 时 间 型 C. 数值 型 
D. 逻辑 型 E. 字符 串 型 
5. 下 列 字段 名 中 ,人 ) 需 要 用 左 单 引 号 “引起 来 。 
A. 姓名 B. 姓 + 名 C. 姓 _ 名 
D. 姓 ' 名 E. 姓 . 名 
6.( ， ) 中 的 英文 字母 区 分 大 小 写 。 
A. 系统 保留 字 B. 系统 函数 名 C. 用 户 名 D. 用 户 密码 
E. 字符 串 常数 F. 数据 库 名 G. 数据 表 名 


7. 通常 在 ( ) 中 能 执行 SQL 语句 。 
A. 记事 本 软件 B. MySQL 命 令 行 ”C. Word 


D. PHPMyAdmin 可 视 化 窗口 E. Excel 

8. 在 图 3-6 的 “修改 登录 信息 /复制 用 户 " 信 息 框 ,能 够 实现 ( ) 功 能 。 
A. 复制 一 个 新 用 户 B. 仅 删 除 原 用 户 
C. 修改 用 户 名 密码 或 主机 D. 为 原 用 户 授权 


E. 修改 用 户 所 属 的 数据 库 
9. 通过 PHPMyAdmin 进行 下 列 相关 操作 ,选择 用 户 应 该 具有 的 权限 : 修改 数据 表 结 
构 (” QD ) ,创建 数据 表 之 间 的 参照 完整 性 (四 “) ,增加 (插入 ) 数 据 记 录 (_ @@_ )， 


修改 (编辑 ) 数 据 记 录 (_@_) ,删除 数据 记录 (名 _) ,创建 用 户 (”@_) ,复制 用 户 
及 其 权限 (_@_)。 





A. Select B. Alter C. Insert D. Update 
E. Delete F. Create User G. Grant 

10. 执行 ( 。 ”) 语 句 能 创建 新 用 户 。 
A. Create User B. Rename User C. Drop User D. Grant 


下 .Show Grants For < 用 户 名 > 
11. 用 户 权限 的 对 象 范围 分 全 局 数据 库 和 表 等 ,(  ”) 是 这 三 个 层次 的 公共 权限 。 
A. Select B. Insert C. Update D. Delete 
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E. File F. Create User 


. 有 关 全 局 和 数据 库 权 限 , 正 确 的 叙述 是 ( )。 


A. 全 局 权限 能 操作 当前 服务 器 中 的 所 有 数据 库 及 相关 对 象 

B. 全 局 权限 仅 能 操作 某 数据 库 及 其 全 部 对 象 

C. 数据 库 权限 能 操作 当前 服务 器 中 的 某 数据 库 及 相关 对 象 

D. 数据 库 权限 能 操作 当前 服务 器 中 的 所 有 数据 库 , 但 不 能 操作 数据 表 
E. 全 局 和 数据 库 权限 都 能 操作 当前 服务 器 中 的 某 数据 库 及 相关 对 象 


. 下 列 叙述 中 ,正确 的 有 ( )。 


A. 先 创建 用 户 后 授权 B. 先 授权 后 创建 用 户 
C. 创建 用 户 和 授权 同时 进行 D. 先 创建 数据 库 后 授权 
E. 先 授权 后 创建 数据 库 


. 在 系统 中 没有 用 户 TU 的 情况 下 ,执行 Grant All On * . * To TU 语句 ,正确 的 叙 


)s 
A. 创建 了 当前 服务 器 用 户 TU 
B. 创建 了 其 他 主机 用 户 TU 
C. 由 于 用 户 TU 还 不 存在 ,因此 ,语句 执行 失败 
D. 为 用 户 TU 授予 了 全 部 全 局 权限 
E. 为 用 户 TU 授予 了 全 部 数据 库 权 限 


. 数据 库 中 主要 包含 ( 。 ”) 对 象 。 


A. 数据 表 B. Excel 表 C. 关联 D. 存储 函数 
E. 图 像 文 件 F. 视图 


. 执行 Create ( 。””)RCZP Character Set = 'UTF8' 能 创建 数据 库 RCZP。 
A. DataBase B. Table C. View D. RCZP 
E. Schema 

. 数据 表 主 要 由 ( ) 两 部 分 构成 。 
A. 关键 字 B. 外 码 C. 数据 表 结构 D. 视图 
E. 数据 记录 

.在 ( ) 中 出 现 减 号 ” - "时 ,要 用 左 单 引号 “将 其 引起 来 。 
A. 表达 式 B. 数值 常数 C. 日 期 型 常数 D. 数据 表 名 
E. 字段 名 

. 数据 表 中 字段 为 ( ) 数 据 类 型 时 ,必须 说 明 长 度 。 
A. Int B. Real C. VarChar D. DateTime 
E. Text F. Char 

. 在 设计 存储 可 枚 举 数据 的 字段 时 ( 如 政治 面貌 和 职称 等 ) ,应 该 选择 ( ) 数 据 
A. Char B. TinyInt C. VarChar D. ENum 
E. Set 


有 关 数 据 表 中 自 增 值 字段 的 正确 叙述 有 (  ” )。 
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A. 一 个 数据 表 中 最 多 有 一 个 自 增值 字段 

B. 一 个 数据 表 中 自 增值 字段 个 数 不 限 

C. 一 个 数据 表 中 可 以 没有 自 增值 字段 

D. 自 增值 字段 必须 是 主键 

E. 新 增 记录 自 增值 字段 值 为 数据 表 中 当前 所 有 记录 的 最 大 值 加 1 
22. 关于 MySQL 数据 表 的 主键 和 关键 字 的 正确 叙述 有 ( Ys 

A. 一 个 数据 表 最 多 有 一 个 主键 B. 一 个 数据 表 主 键 个 数 不 限 

C. 一 个 数据 表 可 以 没有 主键 D. 用 主 索引 定义 主键 

E. 用 唯一 索引 定义 关键 字 F. 用 唯一 索引 定义 非 主键 的 关键 字 
23. 关于 MySQL 索引 的 作用 ,正确 叙述 有 ( »e 

A. 主 索 引 能 控制 记录 避免 重复 B. 唯一 索引 能 控制 记录 避免 重复 


C. 普通 索引 能 控制 记录 避免 重复 D. 主键 能 控制 输出 记录 的 初始 顺序 
E. 普通 索引 用 于 与 其 他 数据 表 创 建 关联 及 参照 完整 性 
24. 有 关 设计 数据 表 间 关联 及 参照 完整 性 ,正确 的 叙述 是 ( )。 
A. 以 子 表 为 当前 数据 表 创建 关联 
B. 创建 关联 时 , 子 表 和 父 表 都 必须 存在 
C. 内 联 的 子 表 只 能 与 父 表 的 关键 字 关 联 
D. 内 联 的 子 表 字 段 必须 索引 
E. 外 键 约束 关联 的 子 表 字 段 必须 为 主 属性 或 索引 
25. 有 关 数据 表 间 内 联 与 外 键 约束 关联 ,正确 的 叙述 是 (  )。 
A. 内 联 没 有 约束 规则 
. 系统 默认 内 联 的 约束 规则 为 限制 
. 外 键 约束 关联 没有 约束 规则 
. 系统 默认 外 键 约束 关联 的 规则 为 限制 
. 系统 默认 外 键 约束 关联 的 规则 为 级 联 
. 系统 默认 内 联 的 约束 规则 为 级 联 
G. 外 键 约束 关联 必须 有 约束 规则 
26. 数据 表 间 设置 更 新 和 删除 数据 记录 的 约束 规则 ,无 论 是 级 联 还 是 限制 ,都 能 执行 
的 操作 有 ( 9 ) , 无 法 进行 的 操作 有 (_ @_)。 
A. 先 删除 父 表 后 删除 子 表 
B. 先 删除 子 表 后 删除 父 表 
C. 输入 父 表 中 与 子 表 无 关联 的 记录 
D. 输入 子 表 中 与 父 表 无 关联 的 记录 
E. 删除 父 表 中 与 子 表 无 关联 的 记录 
了 
C 
H 
下 


各国 加 人 加 


. 删除 父 表 中 与 子 表 有 关联 的 记录 

. 删除 子 表 中 与 父 表 有 关联 的 记录 

. 修改 子 表 中 的 记录 ,使 其 与 父 表 无 关联 
修改 父 表 中 与 子 表 有 关联 记录 的 关联 字段 值 
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27. 在 “浏览 "数据 记录 选项 卡 中 ,对 选中 的 多 个 记录 能 进行 (  ) 操 作 。 


A. 修改 B. 复制 C. 删除 
D. 导入 E. 导出 


1. 什么 是 数据 库 的 物理 设计 ? 数据 库 物理 设计 与 数据 库 人 逻辑 设计 的 关系 是 什么 ? 
应 该 在 什么 软件 中 实施 数据 库 的 物理 设计 ? 

2. MySQL 数据 库 的 常用 管理 工具 PHPMyAdmin 可 视 化 窗口 和 命令 窗口 各 自 的 特点 
是 什么 ? 在 进行 某 些 操作 时 , 哪 种 方式 要 求 用 户 权限 更 多 一 些 ? 

3. 在 MySQL 命令 窗口 中 不 便于 修改 语句 或 输入 汉字 ,通常 采用 什么 方法 解决 这 类 
问题 ? PHPMyAdmin 可 视 化 窗口 和 命令 窗口 都 不 便于 保存 相关 命令 (语句 ) ,通常 采用 什 
么 途径 保存 这 些 语 句 。 

4. 在 一 个 数据 库 管 理 系统 中 不 改变 超级 管理 员 root 的 密码 和 权限 ,可 能 会 给 系统 带 
来 哪些 问题 ? 

5. 在 输入 一 条 命令 或 语句 时 ,哪些 位 置 需要 写 半 角 圆 点 “.”? 哪些 内 容 要 用 引号 引 
起 来 ? 什么 情况 下 的 数据 库 数据 表 或 字段 名 必须 用 左 单 引 号 引起 来 ? 

6. 哪些 内 容 中 的 英文 字母 要 区 分 大 小 写 ? 什么 内 容 之 间 至 少 用 一 个 空格 分 隔 ? 

7. 用 户 分 哪 几 种 类 型 ?要 使 用 户 能 在 当前 服务 器 上 进行 操作 ,应 该 将 其 定义 成 哪 类 
用 户 ? 为 什么 要 创建 任意 主机 (% ) 用 户 ? 

8. 全 局 权限 和 数据 库 权 限 有 哪些 异同 ?为 什么 有 时 要 给 某 用 户 只 授予 数据 库 权 限 ? 

9. 数据 库 中 包含 哪些 对 象 ? MySQL 数据 库 以 什么 形式 存储 ? 数据 表 以 什么 形式 存 
储 ? 创建 数据 库 时 为 何 要 选择 字符 集 ? 

10. 数据 表 间 关联 及 参照 完整 性 是 数据 库 中 的 一 项 重要 技术 , 它 给 实际 应 用 带 来 哪 
些 利弊 ? 对 于 没有 设置 关联 及 参照 完整 性 的 数据 库 , 在 实际 应 用 中 有 哪些 不 便 ? 对 于 设 
置 了 关联 及 参照 完整 性 的 数据 库 ,在 创建 和 删除 数据 表 , 输 入 .修改 和 删除 数据 记录 方面 
有 哪些 限制 ? 

11. 为 什么 要 进行 数据 导出 ? 何 时 需要 数据 导入 ? 将 一 个 数据 库 从 一 台 计 算 机 移植 
到 另 一 台 计 算 机 上 ,应 该 如 何 操作 ? 
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数据 库 访 问 及 结构 化 查询 语言 


数据 库 访问 是 指 操纵 (存储 ) 和 读 取 数据 库 中 的 数据 。 操 纵 数 据 包括 增加 、 修 改 和 删 
除数 据 记录 , 读 取 数 据 有 数据 提取 .查询 和 统计 分 析 等 操作 。 

结构 化 查询 语言 (SQL) 是 访问 关系 型 数据 库 最 有 效 的 通用 工具 ,语句 并 不 多 ,但 每 条 
语句 的 功能 都 非常 强大 ,通常 一 条 语句 相当 于 一 个 子 程序 (模块 ) 的 功能 。 某 些 SQL 语句 
的 结构 比较 复杂 , 仅 掌 握 SQL 语句 的 常用 格式 及 其 功能 , 即 可 满足 实际 应 用 的 要 求 。 

MySQL 是 一 种 关系 型 数据 库 管理 系统 一 DBMS ,如 何 利 用 MySQL 中 的 SQL 语句 访 
问 数据 库 解决 实际 应 用 问题 是 本 章 要 研究 的 主题 ,主要 探讨 下 列 问 题 ， 

(1) SQL 由 哪些 子 语言 构成 ? SQL 的 语法 规则 是 什么 ? 在 什么 环境 中 可 以 编辑 和 运 
行 SQL 语句 ? 

(2) 何 为 数据 定义 语言 7 由 哪些 语句 构成 如 何 使 用 这 些 语句 创建 ,修改 和 删除 数 
据 表 .关键 字 和 表 间 参照 完整 性 ? 

(3) 什么 是 数据 操纵 语言 ”如 何 使 用 数据 操纵 语言 维护 数据 库 中 的 数据 ? 

(4) 什么 是 数据 查询 语言 ”如 何 使 用 数据 查询 语言 进行 数据 查询 .统计 和 分 析 ? 

(5) 如 何 利用 SQL 语句 解决 较 复杂 的 应 用 问题 y”》 有 哪些 解决 问题 的 途径 ? 

(6) 如 何 解决 数据 库 与 其 他 软件 的 数据 交换 问题 ,利用 多 种 渠道 处 理 数据 ? 





4.1 SQL 语句 的 编辑 及 运行 环境 


依据 对 数据 库 的 操作 类 型 不 同 ,标准 的 SQL 分 为 数据 定义 ,数据 操纵 .数据 查询 和 数 
据 库 访问 控制 4 种 子 语言 ,每 种 子 语言 完成 一 类 数据 库 操作 任务 。 

目前 ,关系 数据 库 管理 系统 都 支持 标准 SQL。 在 各 种 DBMS 环境 中 ,对 标准 SQL 支 
持 的 程度 有 些 差异 ,可 能 有 些 取舍 或 扩充 ,特别 是 某 些 DBMS 的 内 部 函数 名 、 格 式 和 功能 
可 能 差异 较 大 ,即使 函数 名 相同 ,其 功能 可 能 也 不 尽 相同 。 因 此 ,在 设计 SQL 语句 引用 内 
部 函数 时 ,需要 查阅 相关 DBMS( 如 MySQL) 的 资料 ,以 便 正 确 使 用 内 部 函数 。 

在 不 同 的 DBMS 环境 中 ,编辑 和 运行 SQL 语句 的 环境 也 有 些 差异 。 在 MySQL 数据 库 
管理 系统 中 ,除了 在 命令 窗口 可 以 编辑 和 运行 SQL 语句 外 ,还 可 以 在 PHPMyAdmin 可 视 
化 窗口 中 编辑 和 运行 SQL 语句 。 在 动态 网 页 设计 中 ,为 使 网 页 程序 能 处 理 数据 库 中 的 数 
据 , 也 需要 在 PHP 程序 代码 中 嵌入 SQL 语句 。 





1. PHPMyAdmin 可 视 化 窗口 


对 于 不 习惯 MySQL 命令 窗口 操作 的 用 户 , 可 以 通过 PHPMyAdmin 可 视 化 窗口 ( 界 
面 ) 的 方式 编辑 .生成 和 运行 SQL 语句 。 

在 成 功 登 录 PHPMyAdmin 后 , 单 击 数据 库 名 (如 RCZP) 一 数据 源 名 (如 GWCJB ) , 进 
和 人 数据 “浏览 "窗口 ,如 图 4-1 所 示 。 











功能 选项 卡 一 全 目 浏 览 纪 结 构 局 SQL 己 搜 索 及 插入 思 导 出 辕 导 入 v 更 多 
生成 或 编写 SELECT * 
A 语句 ”| FROM gwejb 
的 SQL 语句 LIMT0 ,30 
代码 处 理 口 概要 [快速 编辑 [编辑 ] [解释 SOL] [创建 PHP 代码 ][ 刷 新 ] 
工具 
[ERI0 。。 才 下 [50 | 每 [100 | 生生 页 表 二 
主键 排序 [无 习 
+ 选项 
oT 身份 证 号 岗位 编号 资格 审核 笔试 成 绩 面试 成 绩 
口 忆 编 辑 屠 复 制 上 加 删除 119801199210011321 | A0001 1 75 90| 
执行 SQL | 口 编辑 了 复制 器 删除 119801199210011321| A0002 1| 95 0 
语句 的 结果 器 卢 编辑 了 复制 加 删除 229801199305011153 | A0002 0 60 70| 
口 编辑 也 复制 @ 删除 229801199305011153 B0003 十 95 8| 
口 上 编辑 邓 复制 @ 出 除 229901199503121538 | A0002 1 80 85| 
口 ”编辑 也 复制 器 删除 229901199503121538 B0002 1| 90 55 








图 4-1 PHPMyAdmin 的 数据 “浏览 "窗口 


在 数据 浏览 窗口 ,可 以 查看 SQL 语句 和 浏览 查询 的 结果 , 单 击 “ 编 辑 " 代 码 处 理工 具 ， 
进入 SQL 语句 生成 编辑 与 执行 窗口 ,如 图 4-2 所 示 。 


localhost / 127-0.0.1 / rczp / gwcib | phplyAdain 3.5.2.2 ~- Ki... EC | 区 | 
辐 SQL 图 导入 文件 “ 电 SQL 历史 


| 在 数据 库 rezp 运行 SQL 查询 : 加 
SQL 语 民 一 站 [zwssam Iwro 、gwcjb'(\ 身 份 证 号 `，\ 岗 位 编号 ， 攻 必  _ _ _ 
本 机 举人 ` 资 格 审核 "，、 急 这 成 绩 `， "面试 成 绩 `) vALUgs 入 


("119801199210011321", "B0003|", [value-3], 



















































































[value-4], [value-5]) 1 字段 列表 框 
添加 字段 
语 按钮 
a 人 SELECT* ][ SELECT J][ INSERT J[ UPDATE | 
DELETE ][ 清 除 
将 此 SQL 查询 加 为 书签 口 让 所 有 用 户 均 可 访问 此 书签 
口 痊 换 现 有 的 同名 书签 
加 不 从 窗口 外 醒 盖 此 查询 [ 语 各 定 界 符 [ ] 回 在 此 再 次 显示 此 查询 
F SQL 语句 执 
加 | 行 按钮 











饮 本 地 Intranet 


图 4-2 ”生成 .编辑 与 执行 SQL 语句 的 窗口 
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在 SQL 语句 生成 、 编 辑 与 执行 窗口 中 ,可 以 进行 如 下 操作 : 

(1) 生成 与 编辑 SQL 语句 。 单 击 SQL 语句 的 生成 按钮 (如 Insert 和 Delete 等 ) ,在 
SQL 语句 编辑 框 中 生成 对 应 语句 的 模板 ,在 此 基础 上 进行 编辑 修改 ,使 之 成 为 实现 具体 功 
能 的 语句 。 可 以 同时 编辑 和 执行 多 条 语句 ,语句 之 间 用 半角 分 号 "; "并 回 车 分 隔 。 

(2) 向 语句 中 添加 字段 。 在 字段 列表 框 中 , 单 击 某 字段 名 , 选 定 该 字段 ; 先 单 击 某 字 
段 名 ,再 按 住 Shift 键 并 单 击 另 一 个 字段 名 , 选 定之 间 连 续 的 字段 名 ; 按 住 Cul 键 再 单 击 某 
字段 名 ,可 以 选 定 各 个 字段 。 最 后 单 击 添加 字段 按钮 ” < <”, 将 选 定 的 字段 名 添加 到 语 
句 编 辑 框 中 的 插入 点 位 置 。 也 可 以 直接 双击 字段 列表 框 中 的 字段 名 ,在 语句 编辑 框 的 插 
入 点 位 置 添 加 字段 名 。 

(3) 执行 语句 。 单 击 “ 执 行 " 按 钮 ,开始 执行 语句 ,随后 可 以 查看 运行 效果 。 如 果 运 
行 有 错误 , 则 需要 单 击 * 编 辑 " 代 码 处 理工 具 , 修 改 语句 后 再 重新 执行 。 


2. 在 PHP 程序 中 其 入 SQL 语句 


在 PHP 程序 代码 中 嵌入 SQL 语句 ,是 通过 网 页 访问 数据 库 的 一 种 重要 技术 手段 。 
PHP 允许 以 字符 串 的 形式 将 SQL 语句 嵌入 在 程序 中 。 当 用 户 浏览 网 页 时 ,系统 通过 调用 
函数 提交 SQL 语句 ,从 网 络 数据 库 读 取 数据 ,并 将 处 理 结果 显示 在 网 页 上 。 

【 例 4.1】 在 记事 本 软件 中 ,编写 能 查询 岗位 申报 人 次 的 网 页 程序 CXGWSB. PHP。 


<Html > 
<Head ><Meta charSet ="utf -8"/ ><Title 音 询 岗位 申报 人 次 </Title ></Head > 
<Body ><H1 > 
<?PHP 
FWQ MySQL Connect ("LocalHost :3306", "YPRY", "") Or 
Die ("数据 库 服 务 器 连接 失败 ! <Br >") ; // 连 接 数 据 库 服务 器 " LocalHost:3306" 
MySQL Select DB ("RCZP", FWOQ) Or 
Die ("选择 当前 数据 库 失 败 ! <Br >") ; // 选 择 当前 数据 库 为 RCZP 
SJ="Select Count (* ) From GWCJB"; // 将 SQL 语句 以 字符 数据 形式 存 于 变量 YJ 
SG MySQL Query ( YJ, EWO); // 执 行 SQL 语句 
If ( SG) 
SR -MYSQL Fetch Array ( 9G,MYSQOL NOM); // 查 询 结果 存 于 数组 SR 
If (SR) 
Echo "岗位 申报 :", SR[0]," 人 次 <br >"; // 输 出 统计 结果 
Else 
Echo "无 人 岗位 申报 ! <br >"; 
} 
Else 
Echo "查询 岗位 申报 人 次 失败 ! <br >"; 
2> 
</HL ></Body > 
</Html > 
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在 编辑 CXGWSB. PHP 程序 时 ,SQL 语句 Select Count( * ) From GWCJB 以 字符 串 数 
据 的 形式 赋 给 变量 $ YJ, 并 将 其 作为 函数 MySQL_Query 的 参数 。 在 执行 CXGWSB. PHP 
时 ,系统 调用 函数 MySQL_Query 提交 SQL 语句 ,并 获得 操作 数据 库 的 结果 。 

函数 MySQL_Query 不 仅 能 提交 查询 语句 ,也 能 提交 其 他 语句 ( 如 Insert、Delete 和 
Update 等 ) ,并 获取 操作 结果 。 

将 网 页 程序 CXGWSB. PHP 文件 存储 在 XAMPP 软件 安装 目录 下 的 文件 夹 
\HTDOCS 中 (默认 网 站 发 布 目录 ) ,在 网 页 浏览 器 的 地 址 栏 中 输入 Http://LocalHost/ 
CXGWSB. PHP, 即 可 将 SQL 语句 处 理 的 结果 显示 在 网 页 上 ,如 图 4-3 所 示 。 

外 查询 岗位 申报 人 次 - 硬 crosoft Internet Exp.-- 攻 | 冲 | 区 
文件 于) ”编辑 区) 查看 QD 收藏 由 ) 工具 G) 帮助 0 
@aa-©- 国 四 Pe in 加“ 


| 简 http://Localhost/CXGWSB. PHP 





岗位 申报 : 13 人 次 





SQL 语 句 统计 的 结果 
图 4-3 网络 浏览 器 中 显示 数据 的 统计 结果 


在 实际 应 用 中 ,编辑 和 运行 SQL 语句 的 环境 还 有 许多 。 例 如 ,在 MySQL 程序 (存储 
过 程 或 函数 ) 中 ,可 以 直接 编写 语句 ;在 运行 MySQL 程序 时 ,执行 SQL 语句 ,并 进行 数据 
库 操 作 。 另 外 ,还 有 一 些 其 他 软件 (如 Navicat 和 MySQL Workbench 等 ) 都 可 以 编辑 和 运 
行 SQL 语句 。 用 户 可 根据 个 人 的 操作 习惯 和 应 用 开发 环境 ,掌握 其 中 一 两 种 工具 即 可 熟 
练 操作 MySQL 数据 库 。 


4.2 创 建 表 


数据 表 设 计 与 维护 主要 是 将 数据 库 逻 辑 设计 阶段 的 关系 模式 在 DBMS 控制 下 进行 实 
施 , 完 成 数据 库 中 表 的 物理 设计 。 具 体 实施 手段 包括 创建 与 修改 表 结 构 , 设 计 主 关 键 字 
(主键 ) 和 数据 参照 完整 性 等 操作 。 

SQL 的 数据 定义 语言 (Data Definition Language,DDL) 是 实现 表 设 计 与 维护 的 专用 语 
言 ,由 建立 表 结 构 ( Create Table) ,修改 表 结 构 ( Alter Table) 和 删除 表 ( Drop Table ) 语 名 
组 成 。 

创建 表 除了 设计 表 结 构 中 的 信息 (字段 名 .数据 类 型 .宽度 和 默认 值 等 ) 以 外 ,还 可 以 
同时 设计 其 他 相关 内 容 , 如 主键 和 参照 完整 性 等 。 
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4.2.1 创建 表 的 语句 格式 


执行 创建 表 语句 的 用 户 ,应 该 具有 Create 权限 。 
语句 格式 : 


Create Table [If Not Exists] < 表 名 > 
( 字段 名 1> 牧 据 类 型 >[Unsigned] [[Not] Null] [ZeroFil1] 
Default < 常数 >] [Auto Increment] [Primary Key | Unique] 
,和 守 段 名 n> 向 据 类 型 >[ [Not] Nu11] …… ] 
,Primary Key | Unique [ < 键 名 习 | Index [ < 键 名 习 ( 舍 段 名 表 习 ] 
, [Constraint < 外 键 名 1 >] Foreign Key ( < 外 键 字段 名 1 >) 
References < 关联 表 名 1 >( 关联 字段 名 1 > 
[On Delete < 约束 规则 习 [on Update < 约束 规则 习 
, [Constraint < 外 键 名 m >] Foreign Key ( < 外 键 字 段 名 m>) 
References < 关联 表 名 1 >( 关联 字段 名 m>) 
[On Delete < 约束 规则 习 [on Update < 约束 规则 习 ]] 





) 


语句 中 有 关 表 名 .字段 名 .数据 类 型 .Unsigned .Null .ZeroFill Default Auto_Increment 、 
Primary Key 和 Unique 等 选项 的 含义 及 说 明 ,请 参考 第 3 章 的 3.6 节 及 表 3-3 至 表 3-8; 有 关 
References 短语 ( 表 间 关联 及 参照 完整 性 ) 请 参考 3.7.3 节 。 

【 例 4.2】 参照 第 2 章 中 的 表 2-14 ,在 RCZP 数据 库 中 创建 公司 表 。 

Create Table 

公司 表 ( 公司 名 称 VarChar (40) ”Primary Key, 地 址 VarChar (50)， 
注册 日 期 Date, 注册 人 数 smallInt Unsigned Default 100, 
邮政 编码 ”char (6) 
) 7 

在 新 创建 的 “公司 表 ” 中 ， “公司 名 称 ” 字 段 为 主键 ( Primary Key, 非 空 ) , 键 名 为 
Primary。 在 输入 "公司 表 " 中 的 数据 记录 时 ,公司 名 称 "字段 值 可 输入 40 个 字符 或 汉 
字 ( 用 VarChar 数据 类 型 ,一 个 汉字 占 一 个 长 度 ) , 且 * 公 司 名 称 " 字 段 值 不 能 空 ( 至少 输 
入 1 个 字符 ) ;“ 地 址 "字段 值 可 输入 50 个 字符 或 汉字 六 注册 日 期 "字段 值 可 以 输入 日 
期 ,格式 为 YYYY-MM-DD( 年 -月 -日 ); 注册 人 数 " 字 段 输入 无 符号 ( Unsigned)5 位 整 
数 (SmallInt 类 型 无 符号 数据 的 默认 长 度 为 5 位 ) ,范围 为 0 ~65535 ,新 增加 数据 记录 
时 ,注册 人 数 "字段 的 初始 值 ( Default) 为 100; “邮政 编码 "字段 可 以 输入 6 个 字符 或 
数字 。 

在 “公司 表 " 中 , 除 * 公 司 名 称 " 字 段 的 值 不 能 空 外 ,其 他 字段 的 值 均 可 以 不 输入 任何 
数据 , 即 可 以 空 。 

【 例 4.3】 在 RCZP 数据 库 中 创建 论坛 表 , 包 含 文章 序号 、 作 者 文章 内 容 和 更 新 时 
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间 4 个 字段 。 
Create Table 
论坛 表 ( 文章 序号 Int Ruto Increment Primary Key, 
作者 Varchar (20)，, 文章 内 容 Text, 更 新 时 间 Timestamp 
) 7 
其 中 整 型 的 文章 序号 字段 附加 自 增值 ( Auto_Increment) 属性 ,并 设置 为 主键 ,输入 数 
据 记录 时 由 系统 自动 编号 ;更 新 时 间 字 段 为 时 间 蕉 数据 类 型 (TimeStamp) , 当 输入 或 修改 
表 中 数据 记录 的 其 他 字段 值 时 ,DBMS 会 自动 用 系统 时 间 填 写 更 新 时 间 字段 的 值 ,格式 为 
年 -月 -日 时 :分 : 秒 。 


4.2.2 创建 表 的 关键 字 及 索引 


在 MySQL 数据 库 中 , 表 可 以 没有 关键 字 , 但 为 了 避免 重复 输入 数据 记录 ,大 多 数 表 都 
设 关 键 字 , 并 且 , 关 键 字 可 能 由 一 个 或 多 个 主 属性 构成 。 创 建 和 维护 表 时 ,通过 Primary 
Key 短语 创建 主 索引 来 定义 主键 ( 键 名 为 Pimary) ;用 Unique 短语 创建 唯一 索引 来 确定 
其 他 关键 字 。 


1. 一 个 主 属性 的 关键 字 索 引 


当 表 的 关键 字 由 一 个 主 属性 构成 时 ,可 以 在 主 属性 字段 名 及 数据 类 型 说 明之 后 加 
Primary Key 短语 创建 主 索引 ( 主键 , 键 名 为 Primary ) ; 当 表 有 多 个 关键 字 时 ,在 其 他 主 属 
性 字段 后 加 Unique 短语 创建 唯一 索引 (字段 名 即 为 键 名 ) 。 例 如 ,公司 名 称 VarChar(40) 
Primary Key( 见 例 4.2) ,文章 序号 Int Auto_Increment Primary Key( 见 例 4.3) 。 

【 例 4.4】 在 RCZP 数据 库 中 创建 岗位 表 GWB( 设 计 说 明 参 考 第 2 章 的 表 2-11) 和 
应 聘 人 员 表 YPRYB( 设 计 说 明 参 考 第 2 章 的 表 2-12) 。 


Create Table 

GWB ( 岗位 编号 Char (5) Primary Key, 岗位 名 称 VarChar (30) Not Null, 
最 低 学 历 ENum('1','2','3','4','5') Default "3", 
最 低 学 位 ENum("1","2","3","4","5") Default "2", 
人 数 TinyInt Unsigned Default 1, 
年 龄 上 限 TinyInt (2) Unsigned Default 60, 
年 薪 MediumInt (8) Default 36000, 
笔试 成 绩 比 例 TinyInt Unsigned Default 0, 
笔试 日 期 Date, 聘任 要 求 TinyText, 公司 名 称 VarChar (40)， 

Index GS (公司 名 称 ) 
) 7 


在 创建 GCWB 表 的 同时 ,设置 以 公司 名 称 字段 为 索引 关键 字 的 普通 索引 , 键 名 为 GS， 
为 GWB 与 公司 表 建 立 关联 做 准备 。 


Create Table 
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YPRYB ( 身份 证 号 Char (18) Primary Key, 
姓名 VarChar (10), 婚 否 Boolean Default 0， 
最 后 学 历 ENum('1','2','3', '4','5') Default '3', 
最 后 学 位 ENum('1', '2','3', '4','5') Default '2", 
所 学 专业 VarChar (30), 通信 地 址 VarChar (50)， 
邮政 编码 Char (6) ，Email 账号 VarChar (30)， 
QQ 账号 ”Varchar (30)， 固定 电话 VarChar (20)， 
移动 电话 VarChar (15)，, 密码 VarChar (10)，, 个 人 简历 Text 
); 
由 于 岗位 编号 单独 构成 GWB 的 主键 ,身份 证 号 也 单独 构成 YPRYB 的 主键 ， 
此 ,在 Create Table 语句 中 对 应 字段 之 后 直接 加 Primary Key 短语 , 即 可 创建 对 应 表 的 


2. 多 个 主 属性 的 关键 字 及 索引 


当 表 的 关键 字 由 多 个 字段 ( 主 属性 ) 构 成 时 ,需要 在 所 有 字段 描述 之 后 加 Primary Key 
(< 字段 名 表 > ) 短语 定义 主键 , 键 名 ( 即 索引 名 称 ) 仍然 是 Primary; 用 Unique [ < 键 名 
> ]( < 字段 名 表 > ) 短语 定 义 其 他 关键 字 , 省 略 键 名 时 ,字段 名 表 中 的 第 一 个 字段 名 即 为 
键 名 。 其 中 字段 名 表 由 关键 字 中 的 主 属性 构成 ,每 个 字段 名 后 可 以 加 ASC( 默认 ,升序 排 
序 ) 或 DESC( 降 序 排序 ) 短 语 ,控制 数据 的 排序 方式 。 字 段 名 之 间 用 半角 逗号 “, "分隔 ， 
当然 , 仅 由 一 个 字段 构成 关键 字 时 不 需要 逗号 。 

一 个 表 中 可 以 没有 主键 或 者 有 一 个 主键 ,因此 ,在 一 条 Create Table 语句 中 ,Primary 
Key 短语 不 能 出 现 两 次 及 以 上 。 当 多 个 字段 构成 主键 时 ,不 要 在 描述 每 个 字段 时 都 加 
Primary Key 短语 ,只 写 一 次 * ,Primary Key( < 字段 名 表 > ) "短语 定义 组 合 主键 即 可 。 但 
是 ,可 以 多 次 使 用 Unique 短语 定义 多 个 关键 字 。 

在 Create Table 语句 中 ,所 有 字段 描述 之 后 ,也 可 以 多 次 用 Index [ < 键 名 > ] ( < 字段 
名 表 > ) 短 语 创建 普通 索引 ,字段 名 表 可 包含 一 个 或 多 个 索引 字段 ,每 个 字段 名 后 也 可 以 
加 ASC 或 DESC 短语 。 当 省 略 键 名 时 ,字段 名 表 中 的 第 一 个 字段 名 即 为 键 名 。 例 题 4. 4 
中 的 Index GS( 公 司 名称 ) 短语, 用 于 创建 公司 名 称 字段 索引 ,公司 名 称 的 排序 方式 为 升 
序 , 键 名 (索引 名 称 ) 为 GS。 


4.2.3 表 的 外 键 .关联 及 参照 完整 性 


表 的 外 键 不 是 本 表 的 关键 字 ( 但 可 能 是 主 属性 ,如 GWCJB 中 的 身份 证 号 和 岗位 编 
号 ) ,而 与 其 他 表 的 关键 字 对 应 (字段 名 可 以 不 同 ,但 含义 必须 相同 ) ,例如 ,身份 证 号 是 
YPRYB 的 主键, 岗位 编号 是 GWB 的 主键 。 外 键 通常 用 于 本 表 与 其 他 表 创建 关联 ,通过 关 
联 除 实现 表 之 间 的 联系 外 ,还 可 以 设置 表 之 间 的 参照 完整 性 约束 规则 , 即 ,外 键 约束 关联 。 

在 Create Table 语句 中 , 用 [Constraint < 外 键 名 > ] Foreign Key ( < 字段 
名 > ) References < 关联 表 名 > ( < 关联 字段 名 > ) 短语 创建 表 之 间 的 关联 ,同时 用 
On …… < 约束 规则 > 短语 设置 表 之 间 的 参照 完整 性 。 使 用 Constraint < 外 键 名 > 短语 为 
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外 键 命名 ,以 便 在 其 他 语句 中 引用 外 键 。 

【 例 4.5】 在 RCZP 数据 库 中 创建 岗位 成 绩 表 GWCJB (设计 说 明 参 考 第 2 章 
表 2-13) 。 

Create Table 

GWCOB ( 身份 证 号 Char (18) ”Not Null, 岗位 编号 Char (5) Not Null, 
资格 审核 Boolean ”Default 0, 笔试 成 绩 TinyInt Unsigned Default 0， 
面试 成 绩 TinyInt Unsigned Default 0，Primary Key (身份 证 号 ,岗位 编号 ) ， 
Constraint GWCJB_FKl Foreign Key (身份 证 号 ) References YPRYB (身份 证 号 ) 
On Delete Cascade On Update Cascage, 
Constraint GWCJB_FK2 Foreign Key (岗位 编号 ) References GWB( 岗 位 编号 ) 
On Delete Restrict On Update Restrict 
) 7 

在 新 创建 的 GWCJB 表 中 , (身份 证 号 ,岗位 编号 ) 是 主键 ,身份 证 号 和 岗位 编号 分 别 
是 两 个 主 属性 ,也 是 两 个 外 键 。GWCJB( 子 表 ) 通过 外 键 身份 证 号 与 YPRYB( 父 表 ) 建立 
关联 ;用 外 键 岗位 编号 与 CWB( 父 表 ) 建立 关联 ,同时 与 两 个 父 表 分 别 设置 (0n…… 短 语 ) 
参照 完整 性 。 所 谓 参 照 完 整 性 就 是 删除 或 修改 表 中 数据 记录 时 表 之 间 的 约束 规则 。 

在 执行 Create Table 语句 时 ,可 以 选择 创建 或 不 创建 表 之 间 的 关联 。 而 创建 外 键 约束 
关联 (加 Foreign Key … References 短语 ) 的 同时 一 定 要 设置 表 间 的 参照 完整 性 ,如 果 不 加 
On Update 或 On Delete 短语 , 则 系统 自动 将 删除 和 更 新 记录 的 约束 规则 都 设置 为 Restrict 
(限制 ) 。 


4.3 表 及 其 结构 维护 


通过 MySQL 中 的 语句 可 以 查看 .删除 和 更 名 数据 库 中 的 表 , 也 可 以 进一步 调整 和 修 
改 表 的 结构 信息 。 


4.3.1 表 结 构 维护 


当 数据 库 中 表 的 结构 局 部 还 不 符合 要 求 时 ,可 以 运行 修改 表 结 构 的 语句 (Alter 
Table ) 进一步 进行 调整 。 在 原 表 结构 基础 上 ,调整 内 容 包括 增加 、 删 除 和 修改 相关 信息 。 
执行 表 结 构 维护 语句 的 用 户 必须 具有 Alter 权限 。 

语句 格式 : 

Alter Table < 表 名 > 

[[,] aad 寺 段 名 > 疝 据 类 型 >[ 插 加 属性 >] ] 

[[,] Add Primary Key < 主 属性 名 表 习 

[[,] Ad Unique < 键 名 >< 主 属性 名 表 习 

[[,]Add Index < 键 名 >< 舍 段 名 表 习 

[ [,] Agq [Constraint < 外 键 名 >] Foreign Key ( 守 段 名 >) 
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References < 关联 表 名 >( < 侨联 字段 名 习 
[On Delete < 约束 规则 习 [on Update < 约束 规则 习 ] 
[ ,] Drop < 他 段 名 习 
[ ,] Drop Primary Key ] 
[ ,] Drop Index < 键 名 习 
[ ,] Drop Foreign Key < 外 键 名 > 
[ ,] Rename < 新 表 名 习 
[ ,] Change < 原 字 段 名 >< 新 字段 名 >< 数 据 类 型 >[ 和 奉 加 属性 >]] 
[,] Modify < 舍 段 名 >< 数 据 类 型 >[ 符 加 属性 >] ] 
[,] Alter < 字段 名 >Set Default < 常数 >| Drop Default] 


在 一 条 Alter Table < 表 名 > 之 后 ,可 以 加 多 个 短语 ( Add … Drop … 和 Modify … 等 ) ， 
各 个 短语 之 间 用 半角 逗号 “, ”分隔 。 


1. 增加 表 结 构 信息 


Add 短语 用 于 向 表 结 构 中 添加 信息 ,与 Create Table 语句 中 相关 短语 的 功能 和 用 法 基 
本 相同 。 

【 例 4.6】 向 公司 表 中 增加 简介 Text 备注 Text .注销 Tinyint(1) Default 0、 密 码 
VarChar(10) 和 宣传 片 LongBLOB 5 个 字段 ,以 地 址 和 注册 日 期 为 关键 字 创 建 唯一 索引 
DZRQ ;将 GWB 与 公司 表 通 过 公司 名 称 建立 关联 。 

Alter Table 公司 表 add 简介 Text, rdd 备注 Text， 

Rdd 注销 Tinyint (1) ”Default 0, Pd 宣传 片 LongBLOB， 
Rdd 密码 VarChar (10)， 
Rdd Unique DZRQ (地 址 , 注册 日 期 ) ; 


Alter Table GWB add Constraint FK Foreign Key (公司 名 称 ) 
References 公司 表 (公司 名 称 ) On Delete Cascade On Update Cascade; 


2. 删除 表 结 构 信 息 

使 用 Drop 短语 可 以 删除 表 结 构 中 的 相关 信息 。 

【 例 4.7】 删除 公司 表 中 的 备注 字段 和 唯一 索引 DZRQ。 

Alter Table 公司 表 Drop 备注 ,Drop Index DZRQ; 

值得 注意 的 是 ,要 删除 表 的 唯一 索引 ,也 用 Drop Index 短语 ,而 不 用 Drop Unique。 
3. 修改 表 结 构 信息 


在 Alter Table < 表 名 > 语句 中 ,加 Rename 短语 可 以 实现 表 更 名 ,加 Change 短语 进行 
字段 改名 ,加 Modify 短语 修改 字段 的 数据 类 型 ,加 Alter 短语 设置 或 删除 字段 的 默认 值 。 

【 例 4.8】 将 例题 4.3 创建 的 “论坛 表 " 改 名 为 “论坛 ” ;增加 文章 主题 VarChar(100) 
字段 ;将 原 有 “作者 "字段 的 默认 值 设 为 “匿名 人 士 " ;文章 内 容 " 字 段 名 改 为 内容”。 
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Alter Table 论坛 表 ”Rename 论坛 ，Rdd 文章 主题 VarChar (100) ， 
Alter 作者 Set Default ' 匿 名 人 士 '，cChange 文章 内 容 ”内容 Text; 


在 使 用 Change 短语 实现 字段 改名 时 ,一 定 要 写 出 改名 后 的 数据 类 型 ,即便 数据 类 型 
保持 不 变 也 要 如 此 。 


4.3.2 有关 表 及 结构 的 其 他 操作 


在 MySQL 中 ,还 有 一 些 用 于 操作 表 及 其 结构 的 语句 。 
1. 查看 表 的 结构 信息 

语句 格式 : 

Show Columns { From |In } [ < 数据 库 名 >.] < 表 名 > 


查看 当前 数据 库 中 的 表 结 构 时 ,可 以 不 写 数 据 库 名 和 “.”。 
【 例 4.9】 输出 RCZP 数据 库 中 GWB 的 表 结构 。 


Show Columns From RCZP .GWB; 
输出 结果 如 表 4-1 所 示 。 
表 4-1 GWB 的 表 结 构 















































字段 数据 类 型 可 和 否 为 空 主键 默认 值 
岗位 编号 Char(5) 否 PRI Null 
岗位 名 称 VarChar( 30) 否 Null 
最 低 学 历 是 3 
最 低 学 位 ee 和 是 2 
人 数 TinyInt(3) Unsigned 是 1 
年 龄 上 限 TinyInt(2) Unsigned 是 60 
年 薪 MediumInt(8) 是 36000 
笔试 成 绩 比 例 TinyInt(3) Unsigned 是 0 
笔试 日 期 Date 是 Null 
聘任 要 求 TinyText 是 Null 
公司 名 称 VarChar( 40) 是 Null Null 
2. 更 改 表 名 

虽然 在 Alter Table 语句 中 加 Rename 短语 可 以 实现 表 更 名 ,但 MySQL 还 有 专门 用 于 
更 改 表 名 称 的 语句 。 
语句 格式 : 
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Rename Table < 表 原 名 并 o < 表 新 名 > 


3. 删除 表 

删除 表 是 指 删 除 表 结 构 及 其 表 中 的 数据 记录 。 要 删除 有 参照 完整 性 的 父 表 , 应 该 先 
删除 子 表 中 的 外 键 (Drop Foreign Key ) 或 删除 子 表 。 

语句 格式 : 

Drop Table [If Exists ] < 表 名 表 > 

执行 Drop Table 语句 的 用 户 应 该 有 Drop 权限 ;执行 一 条 Drop Table 语句 可 以 同时 删 
除 多 个 表 , 表 名 之 间 用 逗号 分 隔 。 在 语句 中 加 芋 Exists 短语 ,可 以 避免 因 删 除 不 存在 的 表 
而 引发 系统 出 错 。 

4. 查看 数据 库 中 的 表 

语句 格式 : 

Show Tables [ {From |In} < 数据 库 名 习 

如 果 查 看 当前 数据 库 中 的 表 名 , 则 可 以 不 写 From1In < 数据 库 名 > 短语 。 

5. 复制 表 结 构 

语句 格式 : 

Create Table [If Not Exists] < 新 表 名 并 ike < 源 表 名 > 


按 源 表 的 结构 (包括 索引 数据 类 型 和 默认 值 等 ) 创建 新 表 , 但 不 填写 数据 记录 , 即 创 
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表达 式 主要 实现 语句 的 运算 功能 ,以 便 完成 较 复杂 的 计算 和 逻辑 判断 任务 。 常 数 、 变 
量 (字段 ) 和 函数 是 基本 的 表达 式 , 通 过 运算 符号 连接 表达 式 构成 较 复杂 的 表达 式 , 运 算 
符号 与 数据 的 类 型 有 关 。 

在 一 个 表达 式 中 可 以 通过 函数 名 、 小 括号 和 参数 (有 些 函 数 没 有 参数 ) 调用 函数 , 获 
得 处 理 (运算 ) 后 的 一 个 结果 ( 称 为 返回 值 ) ,作为 表达 式 中 的 一 个 运算 项 。 例 如 ,2 * 
Sqrt(25 ) ,系统 先 调用 算术 平方 根 函 数 Sqrt( 函数 名 ) ,对 25 (参数 ) 进行 开平 方 运算 ,返回 
函数 值 为 5 ,再 进行 2*5 运算 ,最 后 得 到 结果 为 10。 

在 MySQL 中 ,可 用 Select < 表达 式 > 语句 在 命令 行 方式 下 测试 和 输出 表达 式 的 值 。 

【 例 4.10】 在 MySQL 的 命令 窗口 ,输出 表达 式 2 * Sqrt(25 ) 的 值 。 


mysq] >Select 2 * Sqrt(25); 
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1 row in set (0.12 sec) 

mysql > 

函数 的 参数 也 是 表达 式 , 甚 至 可 以 是 另 一 个 函数 调用 , 即 函数 的 嵌 套 调用 。 例 如 ， 
Sqrt( ABS( -19 % 10) ) ,调用 Sqrt 时 , 先 调用 绝对 值 函数 ABS( - 19 % 10) ,继而 最 先 计 
算 -19 % 10 得 到 -9, 再 对 -9 求 绝对 值得 到 9 ,最 后 对 9 进行 开平 方 运 算得 结果 为 3。 

函数 分 内 置 函 数 和 用 户 自 定义 函数 两 种 ,内 置 函 数 是 系统 定义 的 函数 ,也 称 系统 函 
数 ,标准 函数 ,简称 函数 。 内 置 函 数 的 用 法 与 运算 符 类 似 , 用 户 可 以 直接 调用 ,完成 相关 的 
计算 任务 。 


4.4.1 算术 运算 符 及 常用 的 数学 函数 


算术 运算 符 和 数学 函数 主要 用 于 数值 型 数据 的 统计 分 析 及 科学 计算 ,运算 结果 仍然 
是 数值 型 。 


1. 算术 运算 符 


算术 运算 符 有 + (加 法 )、- (减法 或 取 负 运算 ) 、* (乘法 ) (除法 ) ,Div( 整数 商 ,如 
13 Div 4 的 值 为 3) 和 % ( 求 模 , 即 余数 运算 ,如 13 % 4 的 值 为 1)。 

算术 运算 的 优先 级 别 遵循 数学 中 的 规定 ,可 以 加 小 括号 ”() "改变 运算 的 优先 级 别 ， 
并 且 小 括号 可 以 多 层 嵌 套 ,内 层 小 括号 中 的 算式 优先 于 外 层 小 括号 。 例 如 ,7*5%2 的 值 
为 1, 而 7*(5%2) 的 值 为 7。 

2. 数学 函数 

数学 函数 是 以 数值 型 数据 为 参数 ,返回 值 也 是 数值 型 数据 的 函数 。 有 如 下 常用 函数 ， 
其 中 参数 XY 和 均 代 表 表 达 式 。 

(1) ABS(X) : 绝对 值 函 数 。 返 回 X 的 绝对 值 。 例 如 ,ABS( -5.1) 和 ABS(5.1) 的 值 
均 为 5.1。 

(2) Mod(X,Y) : 求 模 函 数 。 返 回 X 除 以 Y 后 所 得 的 余数 ,与 运算 符 % 功能 相同 。 矣 
数 返回 值 是 实数 ( 可 能 含 小 数 ) ,其 符号 取决 于 被 除数 (X) 的 符号 。 例 如 ,Mod(5,2) 和 
Mod(5, -2) 的 值 均 为 1,Mod( -5,2) 和 Mod( -5, -2) 的 值 均 为 -1,Mod(1,0.3) 的 值 为 
O, Ls 

(3) Power(XY,m) : 指数 函数 。 返 回 XY 的 值 , 和 的 值 均 为 实数 ,但 必须 遵循 数学 
中 的 规定 (如 负数 不 能 开 偶 次 方 )。 例 如 ,Power(5,2) 和 Power( -5,2) 的 值 均 为 25,Power 
(25 ,1/2) 的 值 为 5。 但 Power( -25,1/2) 是 错误 的 。 
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(4) Sqrt( < 蕊 > ) : 开平 方 函 数 。 返 回 X 的 算术 平方 根 ,X 宇 0, 与 Power(X,1/2) 功 能 
相同 。 例 如 ,Sqrt(25 ) 的 值 为 5,Sqrt(2) 的 值 为 1.414。 

(5) Ceiling(X) : 取 天 棚 函 数 。 返 回 大 于 或 等 于 式 值 的 最 小 整数 。 例 如 ,Ceiling(5.1) 
的 值 为 6,Ceiling( -5.1) 的 值 为 -5。 

(6) Floor(XY) : 取 地 板 函 数 。 返 回 小 于 或 等 于 X 值 的 最 大 整数 。 例 如 ,Floor(5.1) 的 
值 为 5,Floor ( -5.1) 的 值 为 -6。 

(7) Round(X[ ,n]): 四 舍 五 和 函数。 返回 X 四 舍 五 人 后 的 值 。 当 n=0 时 ,可 以 不 
写 * ,0” ,表示 在 小 数 点 后 第 一 位 上 四 舍 五 人 , 仅 保留 整数 ;n 宇 1 时 ,表示 在 小 数 点 后 第 
n+1 位 上 四 舍 五 人 ,保留 整数 和 位 小 数 ;n< -1 时 ,表示 在 整数 第 lnl 位 上 四 舍 五 人 ,第 
Inl 及 低位 填 0 占 位 。 例 如 , Round (15. 7654 ) 的 值 为 16, Round (15.7654,2) 的 值 为 
15.77,Round(15.7654，-1) 的 值 为 20。 

(8) Truncate(X,n) : 舍 去 函数 。 返 回 工 截取 ( 舍 去 ) 后 的 值 。 当 于 =0 时 , 舍 去 整个 
小 数 , 仅 保留 整数 ;n 三 1 时 ,保留 整数 和 位 小 数 ;n< -1 时 ,表示 舍 去 整数 第 ln1 位 及 
低位 的 值 , 1n1 及 低位 整数 位 填 0 占 位 。 例 如 , Truncate (15.7654,0) 的 值 为 15， 
Truncate(15.7654,2) 的 值 为 15.76,Truncate(15.7654, 一 1) 的 值 为 10。 


4.4.2 ”常用 日 期 时 间 耳 数 


日 期 时 间 函 数 是 指 对 日 期 及 时 间 型 数据 进行 运算 的 函数 ,一 般 用 于 日 期 时 间 提 取 \ 转 
换 和 时 间 分 析 等 。MySQL 没有 提供 日 期 时 间 的 运算 符 , 一 切 运算 完全 依靠 函数 。 此 类 函 
数 返回 值 可 能 是 日 期 .时间 .日 期 时 间 数值 或 字符 串 型 数据 。 有 如 下 常用 函数 ,参数 D 
代表 日 期 (时 间 ) 表 达 式 ,n 代表 数值 表达 式 。 

(1) CurDate( ) : 系统 当前 日 期 函数 。 返 回 值 为 系统 的 当前 日 期 ,格式 为 YYYY-MM- 
DD( 年 -月 -日 ) 。 该 函数 没有 参数 ,但 调用 该 函数 时 ,小 括号 不 能 省 略 ,以 下 相同 。 

(2) CurTime( ) : 当前 时 间 函 数 。 返 回 值 为 系统 的 当前 时 间 , 格 式 为 HH:MM:SS 
(时 :分 : 秒 ) 。 

(3) Now( ) 与 SysDate( ) : 系统 当前 日 期 时 间 函 数 。 两 个 函数 功能 相同 , 均 返 回 计算 
机 系统 的 日 期 时 间 。 格 式 为 YYYY-MM-DD HH:MM:SS。 

(4) AddDate(D,n): 日 期 加 天 数 函 数 。 返 回 D 加 天 的 日 期 (时 间 ) ,n <0 时 ,得 到 
In| 天 前 的 日 期 (时 间 ) ;n=0 时 ,得 到 n 天 后 的 日 期 (时 间 )。 函 数 返 回 值 的 数据 类 型 由 DD 
的 数据 类 型 决定 。 日 期 型 数据 的 格式 为 YYYY-MM-DD; 日 期 时 间 型 数据 的 格式 为 YYYY- 
MM-DD HH:MM:SS。 例 如 , AddDate (' 1949-10-1' ,100 ) 的 值 为 1950-01-09, AddDate(' 
1949-10-1 15 :00:00' ,-100) 的 值 为 1949-06-23 15 :00:00。 

(5) Time(D): 截取 时 间 函 数 。 返 回 D 值 的 时 间 部 分 ,格式 为 HH:MM:SS( 时 :分 : 
秒 ) ,Time( Now( ) ) 与 CurTime( ) 功 能 相同 。 例 如 ,Time('1949-10-1 15:00:00' ) 的 值 为 
15 :00:00。 

(6) WeekDay(D): 周 几 函数 。 返 回 也 对 应 的 工作 日 ( 周 几 ) ,范围 为 0 ~6。0 为 周 
一 ,1 为 周二 ……6 为 周 日 , 即 按 我 国 工作 日 的 习惯 ,WeekDay(D) +1 的 值 恰 为 周 几 。 例 
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如 ,WeekDay('1949-10-1 ) +1 的 值 为 6( 周 六 ) 。 

(7) DayO0fWeek(D): 周 几 函数 。 返 回 D 对 应 的 工作 日 ( 周 几 ) ,范围 为 1 ~7。1 为 周 
日 ,2 为 周一 ……7 为 周 六 。 例 如 ,DayOfWeek('1931-9-18' ) 的 值 为 6( 周 五 ) 。 

(8) DayName(D): 周 几 名 函数 。 返 回 日 期 对 应 的 工作 日 ( 周 几 ) 英 文 名 字符 串 。 例 
如 ,DayName('1931-9-18' ) 的 值 为 : Friday。 

(9) MonthName(D) : 月 份 名 函数 。 返 回 日 期 D 对 应 的 月 份 英文 名 字符 串 。 例 如 ， 
MonthName('1931-9-18' ) 的 值 为 September。 

(10) Year(D): 年 份 函 数 。 返 回 日 期 D 的 年 份 数值 ,范围 为 1000 ~9999。 例如， 
Year('31-9-3' ) 的 值 为 2031。 

(11) DateDiff( D, ,D, ) : 日 期 差 函 数 。D, 与 D, 之 间 的 天 数 , 若 D, 宇 D,, 则 函数 返回 
值 为 大 于 或 等 于 0 的 整数 ,否则 为 负数 。 例 如 ,DateDiff('2018-10-1','1949-10-1') 和 
DateDiff('2018-10-1 23 :59:59' ,'1949-10-1 0:0:0' ) 的 值 均 为 25202; DateDiff('1949-10-1 
' ,2018-10-1 ) 的 值 为 -25202。 

(12) TimeDiff( DD ,D,): 时 间 差 函数 。 两 个 日 期 时 间或 两 个 时 间 之 间 相 隔 的 时 长 , 函 
数 返回 值 的 范围 为 -838 :59:59 ~838:59:59, 即 函数 只 适合 计算 不 超过 34 天 23 小 时 的 
时 间 间 隔 。 例 如 ,TimeDiff('2018-1-4 7:10:10' ,'2018-1-1 0:30:20' ) 的 值 为 78:39:50。 


4.4.3 常用 字符 串 函 数 


字符 串 函 数 主要 用 于 字符 串 型 数据 (参数 ) 的 提取 ,连接 ,整理 和 转换 等 ,返回 值 可 能 
是 字符 串 或 数值 型 数据 。MySQL 也 没有 提供 字符 串 型 的 运算 符 , 一 切 运算 完全 依靠 函 
数 。 有 如 下 常用 函数 ,其 中 $ 表示 字符 表达 式 ,N 入 均 表 示 数 值 表达 式 。 

(1) ASCII( 5) : 字符 编码 函数 。 返 回 5 值 中 首 字 符 的 机 内 码 ,范围 为 0 ~255 ,0 表示 
S 为 空 串 ,1 ~ 127 表示 英文 符号 ,128 ~ 255 表示 汉字 或 全 角 符号 。 例 如 , ASCII(' Data 
Base' ) 的 值 为 68 ;ASCII(' 数 据 库 ' ) 的 值 为 230。 

(2) Char(N[ ,N…] ) : 编码 转 字符 并 连接 函数 。 将 各 个 参数 (编码 ) 对 应 的 字符 连 
接 成 一 个 字符 串 作 为 函数 的 返回 值 。 例 如 ,Char(73 ,32 ,67 ,65 ,78 ) 的 值 为 “I CAN” ,其 中 
73 ,32 .67 .65 和 78 分 别 是 I 空格 .C、A 和 N 的 ASCII 码 。 

(3) Char_Length( S) : 字符 串 长 度 函 数 。 返 回 $ 中 符号 的 个 数 ( 也 称 字符 串 长 度 ) ， 
每 个 英文 符号 .汉字 和 全 角 符 号 都 记 为 1。 例如 ,Char_Length('Data Base' ) 的 值 为 9,Char 
_Length( ' 数 据 库 ' ) 的 值 为 3。 

(4) Concat( S[ ,S,,…,S,] ) : 字符 串 连 接 函 数 。 返 回 n 个 字符 串 连 接 后 的 字符 串 。 
例如 ,Concat(' 互 联网 +',' 数 据 库 ',' 与 程序 设计 ' ) 的 值 为 “互联 网 + 数据 库 与 程序 设 
证 6 

(5) Concat_WS( < 分 隔 符 > ,S1[ ,5S,,…,5,]): 字符 串 连 接 函 数 。 返 回 个 字符 串 
之 间 插入 分 隔 符 后 再 连接 的 字符 串 。 例 如 ,Concat_WS('1',' 互 联网 +',' 数 据 库 ',' 与 程 
序 设计 ' ) 的 值 均 为 “互联 网 + | 数据 库 | 与 程序 设计 ” ,其 中 “1” 是 分 隔 符 。 

(6) CONV(N, < 当前 进 制 > , < 目标 进 制 > ) : 数 制 转 换 函 数 。N 为 大 于 或 等 于 0 
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的 整数 ,将 NN 的 值 由 当前 进 制 (入 36 ) 转化 到 目标 进 制 (入 36 ) 的 字符 串 作 为 函数 的 返回 
值 。 例 如 ,CONV(30,10,16 ) 的 值 为 IE, 将 十 进 制 30 转换 成 十 六 进 制 后 的 字符 串 为 1E; 
CONV(12,8,2) 的 值 均 为 1010 ,将 八进制 12 转换 成 二 进 制 后 的 字符 串 为 1010; CONV 
(100,10,36) 的 值 为 2S。 

(7) ELT(N,S[ ,S ,…,S。]): 数码 转 名 称 函 数 。N 为 数值 或 数字 串 型 表达 式 , 当 
1<N<m 时 ,函数 返回 S% 的 值 , 否 则 ,函数 返回 值 为 NULL。 一 般 用 于 将 数据 编码 转换 成 
名 称 。 例 如 ,ELT(2,' 男 ',' 女 ' ) 的 值 为 女 ,ELT( 最 低 学 历 无 要 求 ' 专科 ' "本科 ' ， 研 
究 生 ' ,博士 ' ) 的 值 为 最 低 学 历 的 汉字 名 称 。 

(8) Find_In_Set( S, ,S,) : 查找 字符 串 函 数位 置 。 如 果 5, 的 值 等 于 $, 值 中 某 个 子 字 
符 串 , 则 函数 返回 该 子 字符 串 的 首次 出 现 序号 ,否则 ,函数 返回 值 为 0。 在 5, 值 中 ,各 个 
子 字 符 串 之 间 用 半角 逗号 分 隔 ,一 般 用 于 将 名 称 转换 成 数据 编码 。 例 如 , Find_In_Set 
(' 本 科 ' 专科, 本科, 研究 生 ,博士 生 ' ) 的 值 为 2,Find_In_Set(' 女 ',' 男 , 女 ' ) 的 值 为 2。 

(9) Format(X,n) : 转换 千 分 位 函数 。 将 X 的 数值 转换 成 千 分 位 字符 串 ,其 中 为 转 
换 后 的 小 数位 数 ,n < 0 时 按 0 计算 ,在 小 数 n+1 位 上 四 舍 五 人。 例如 ， 
Format(23456789. 675 ,2 ) 的 值 为 字符 串 “23 ,456 ,789. 68”, Format( 8976. 54, -2) 的 值 为 
字符 串 “8,977”。 

(10) InSTR(S,5S,) 和 Locate(5,,S): 子 串 位 置 函 数 。 若 5, 的 值 是 5 中 的 完整 子 串 
(英文 字母 不 区 分 大 小 写 ) , 则 函数 返回 其 首次 出 现 的 位 置 号 ,和 否则 , 函数 返回 值 为 0。 例 
如 ,InSTR(' 吉 林 省 大 学 ' ,吉林 大 学 ' ) 的 值 为 0,InSTR( ' 吉 林 省 大 学 ' ， 大 学 ' ) 和 Locate 
(" 大 学 ' ,吉林 省 大 学 ' ) 的 值 均 为 4。 

(11) Locate( 5 ,S, < 起 始 位 置 > ) : 子 串 位 置 函数 。 从 起 始 位 置 之 后 , 若 5, 的 值 是 $ 
中 的 完整 子 串 (英文 字母 不 区 分 大 小 写 ) , 则 函数 返回 其 首次 出 现 的 位 置 号 ,否则 ,函数 返 
回 值 为 0。 例 如 ,Locate(' 中 国 ',' 中国 是 一 个 发 展 中 国家 ' ,5 ) 的 值 是 8,Locate( ' 发 家 ' ， 
一 个 发 展 中 国家 ' ,3 ) 的 值 是 0。 

(12) Left(S,n): 左 子 串 函数 。 返 回 5 左 起 nn 个 符号 。 例 如 ,Left(' 吉 林 省 大 学 ' ,3) 
的 值 为 “吉林 省 ”。 

(13) Right(5,n): 右 子囊 函数 。 返 回 $ 右 起 向 左 半 个 符号 。 例 如 ,Right( "吉林 省 大 
学 ' ,3) 的 值 为 “省 大 学 ”。 

(14) Mid(5, < 起 始 位 置 >[ ,n]) 和 SubString(5, < 起 始 位 置 >[ ,n]): 任意 子 串 函 
数 。 返 回 值 是 从 5 值 中 起 始 位 置 向 后 的 n 个 符号 。 若 不 写 * ,n" 或 n 值 超过 后 面 的 字符 
个 数 , 则 函数 返回 值 为 从 起 始 位 置 向 后 的 全 部 符号 。 例 如 ,SubString(' 吉 林 省 大 学 ' ,3 ,2) 
的 值 为 “省 大 ” ; Mid(' 吉 林 省 大 学 ' ,3 ) 的 值 为 “省 大 学 ”。 

(15) Lower(S) : 转换 小 写字 母 函 数 。 将 $ 中 大 写 英文 字母 (包括 全 角 字 母 ) 转 换 成 
小 写 ,其 他 符号 不 变 ,函数 返回 转换 后 的 结果 。 例 如 ,Lower('InterNet 与 互联 网 +') 的 值 
为 “internet 与 互联 网 +”。 

(16) Upper(5) : 转换 大 写字 母 函数 。 将 $ 中 小 写 英 文字 母 (包括 全 角 字 母 ) 转换 成 
大 写 , 其 他 符号 不 变 , 函 数 返 回转 换 后 的 结果 。 例 如 ,Upper('InterNet 与 互联 网 +' ) 的 值 
为 “INTERNET 与 互联 网 +”。 
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(17) LTrim(S) : 删除 首 空格 函数 。 返 回 值 为 去 掉 $ 值 中 首部 空格 后 的 字符 串 。 例 
如 ,Concat( "数据 库 ' ,LTrim(” 互联 网 +')) 的 值 为 “数据 库 互 联网 +”, 结 果 删 除了 
“互联 网 + "左边 的 全 部 空格 。 

(18) RTrim(S) : 删除 尾 空格 函数 。 返 回 值 为 删除 $ 值 中 末尾 空格 后 的 字符 串 。 例 
如 ,Concat( RTrim(' 数 据 库 ') ， 互 联网 +" ) 的 值 为 "数据库 互 联网 + ” ,结果 删除 了 
“数据 库 ” 尾 部 的 全 部 空格 。 

(19) Trim(S) : 删除 首尾 空格 函数 。 返 回 值 为 5 值 去 掉 首 尾 空格 后 的 字符 串 。 例 
如 ,Concat( Trim(' 数据 库 ') ,互联 网 +' ) 的 值 为 “ 数 据 库 互 联网 +” ,结果 删 
除了 “ 数 据 库 " 首 尾 全 部 空格 。 

Trim .LTrim 和 RTrim 都 是 删除 对 应 位 置 的 半角 空格 函数 ,但 都 不 能 删除 其 他 字符 中 
间 的 空格 或 全 角 空 格 。 


4.4.4 混合 数据 类 型 的 转换 


在 MySQL 进行 数据 处 理 时 ,对 数据 类 型 的 要 求 并 不 太 严格 。 例 如 ,设计 表达 式 时 , 数 
据 项 的 类 型 可 以 与 运算 符 不 匹配 ;函数 的 参数 可 以 与 要 求 的 数据 类 型 不 一 致 等 。 系 统 并 
不 将 这 种 混合 数据 类 型 的 操作 视 为 错误 ,而 是 在 运算 之 前 ,由 系统 自动 转换 相关 数据 的 类 
型 ,随后 再 对 转换 后 的 数据 进行 运算 。 下 面 介绍 数据 类 型 转换 的 常见 规则 。 


1. 按 算术 运算 符 转换 


用 算术 运算 符 连 接 的 非 数值 型 运算 项 一 律 转换 成 数值 型 运算 项 后 再 运算 。 常 用 数据 
类 型 的 转换 规则 如 下 : 

(1) 字符 串 型 转换 。 将 字符 串 首部 可 转换 成 数值 的 部 分 转换 成 数值 ,再 进行 算术 运 
算 。 例 如 ,5 +'10' 的 结果 为 15,'9' * '40' 的 结果 为 360,'2.5E3'/5 的 结果 为 500，15' -， 
3.5 学 分 的 结果 为 11.5。 

(2) 日 期 (时 间 ) 型 转换 。 将 年 月 日 时 分 秒 依次 连接 后 转换 成 一 个 整数 ,其 中 年 份 占 
4 位 ,其 余 各 占 2 位 。 例 如 ,如 果 系 统 日 期 时 间 函 数 Now( ) 的 值 是 “2018-03-31 15 :32: 
50”, 则 CurDate( ) +5 的 值 为 20180336,Now( ) +15 的 值 为 20180331153265 。 


2. 按 函 数 的 参数 类 型 转换 


当 函 数 的 参数 与 要 求 的 数据 类 型 不 一 致 时 ,将 参数 的 数据 类 型 转换 成 所 要 求 的 数据 
类 型 后 再 进行 函数 运算 。 例 如 ,Left(211985 ,4) 的 值 为 2119,Sqrt('100A' ) 的 值 为 10。 

但 是 ,日 期 (时 间 ) 型 参数 不 能 用 数值 转换 。 例 如 , AddDate (2017-10-1,5 ) 的 值 为 
Null, WeekDay(2017. 10. 1) 是 错误 的 表达 式 。 

系统 在 对 混合 类 型 的 数据 进行 运算 之 前 ,要 进行 相应 的 数据 转换 。 从 上 述 转换 结果 
来 看 ,有 数据 丢失 现象 ,如 '3.5 学 分 ' 变 为 3.5,'100A' 变 为 100。 因 此 ,为 了 避免 数据 丢失 
或 产生 歧义 性 的 结果 ,建议 设计 表达 式 时 要 恰当 地 使 用 数据 类 型 。 
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4.5 增加 数据 记录 


数据 表 主 要 由 表 结 构 和 数据 记录 两 部 分 组 成 , 表 结 构 是 表 的 框架 ,有 了 结构 之 后 才能 
操纵 表 中 的 数据 记录 。 通 常 将 只 有 表 结构 而 没有 数据 记录 的 表 称 为 空 表 。 

SQL 的 数据 操纵 语言 用 于 数据 表 中 的 数据 维护 ,主要 由 增加 ( Insert 和 Replace) .删除 
(Delete) 和 修改 (Update ) 数据 记录 的 语句 构成 。 在 这 些 语 句 中 ,通过 表达 式 增加 、 删 除 和 
修改 数据 记录 。 

在 MySQL 中 ,有 多 种 向 表 中 增加 记录 的 语句 ,执行 任何 增加 数据 记录 语句 ( Insert 或 
Replace ) 的 用 户 都 应 该 有 数据 的 Insert 权限 。 


4.5.1 增加 多 个 记录 


执行 一 条 SQL 的 Insert … Values … 语 句 ,可 以 向 表 中 增加 多 个 数据 记录 。 
语句 格式 : 
Insert [Delayed |Low Priority IHigh Priority] 
[Into] < 表 名 >[( < 舒 段 名 表 习 ] 
Values ( 表达 式 表 1 > … [, ( 表达 式 表 n >)] 
[OnDuplicate Key Update < 他 段 名 1 >=< 表 达 式 1 >… 
[5 字段 名 m>=< 表 达 式 m>]] 


1. 增加 记录 的 优先 级 别 


执行 Insert、Replace .Update 和 Delete 语句 操纵 表 中 的 数据 记录 时 比较 消耗 系统 时 
间 , 会 严重 影响 数据 查询 的 速度 。MySQL 允许 在 这 些 语句 中 加 下 列 短 语 ,以 便 优先 执行 
数据 查询 语句 (Select) ,缩短 数据 检索 时 间 ,提高 整个 网 络 的 运行 效率 。 

(1) Delayed。 当 网 络 中 有 其 他 用 户 正 访问 要 增加 记录 的 表 时 ,将 要 增加 的 数据 记录 
存放 到 缓冲 区 中 ,本 客户 端的 程序 继续 向 下 执行 ; 当 该 表 空 闪 ( 没 有 用 户 访问 ) 时 ,再 由 系 
统 将 数据 记录 实际 存储 到 表 中 。 

(2) Low_Priority。 当 有 用 户 正在 访问 要 增加 记录 的 表 时 ,本 客户 端 暂停 执行 数据 操 
纵 语句 , 当 表 空 闲 后 ,本 客户 端 再 继续 执行 该 语句 及 其 程序 。 即 执行 数据 操纵 语句 的 优先 
权 低 于 数据 查询 语句 (Select) 。 

(3) High_Priority。 本 客户 端 执行 该 数据 操纵 语句 与 其 他 用 户 执行 数据 查询 语句 具 
有 相同 的 优先 权 。 


2. 字段 名 表 
字段 名 表 用 于 指出 要 填 值 的 各 个 字段 名 及 其 顺序 ,字段 名 的 前 后 顺序 可 以 与 表 中 字 
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段 的 顺序 无 关 , 也 可 以 是 表 中 的 部 分 字段 。 省 略 “字段 名 表 ” 表 示 要 填写 表 中 全 部 字段 的 
值 ,并 且 ,字段 的 顺序 与 表 中 存储 字段 的 顺序 一 致 。 


3. Values( < 表达 式 表 i > ) 


一 次 可 以 增加 nm 个 记录 ,用 “表达 式 表 i” 中 各 个 表达 式 的 值 填写 增加 的 第 i 个 记录 对 
应 的 字段 。 每 个 表达 式 表 都 要 用 小 括号 括 起 来 ,对 应 一 个 数据 记录 ,各 个 表达 式 与 字段 名 
表 或 表 中 的 字段 按 前 后 顺序 一 一 对 应 ,并 且 , 希 望 数据 类 型 要 与 对 应 字段 的 数据 类 型 一 
致 ,或 者 可 以 类 型 转换 。 也 可 以 用 下 列 选项 代替 表达 式 。 

(1) Null。 对 于 可 以 为 空 的 字段 ,对 应 表达 式 可 以 用 Nul 表示 ,将 对 应 字段 填 成 Null 
值 。 例 如 ,公司 表 中 的 简介 和 宣传 片 字段 。 

(2) Default。 对 于 有 默认 值 (Default) 、 自 增值 ( Auto_Inerement) 属性 以 及 时 间 戳 类 型 
(TimeStamp ) 的 字段 ,对 应 的 表达 式 可 以 用 Default 表示 。 实 际 上 将 有 默认 值 的 字段 填写 
默认 值 , 自 增 字 段 填 写 自 动 编号 ,时间 截 字段 填写 系统 当时 日 期 时 间 。 


4. 数据 类 型 转换 


当 表达 式 与 对 应 字段 的 数据 类 型 不 一 致 时 ,系统 强制 将 表达 式 的 值 转换 成 字段 的 数 
据 类 型 。 一 般 来 讲 ,数值 和 日 期 (时 间 ) 型 数据 能 准确 地 填 到 字符 串 型 字段 中 ,数字 串 也 
能 正确 地 填 到 数值 型 字段 中 。 但 是 ,其 他 类 型 数据 之 间 的 转换 可 能 产生 数据 丢失 或 歧义 。 
因此 ,建议 要 使 表达 式 与 对 应 字段 的 数据 类 型 一 致 

【 例 4.11】 在 论坛 表 中 增加 1 个 数据 记录 。 

Insert Into 论坛 文章 序号 ,作者 ,内 容 , 更 新 时 间 , 文 章 主 题 ) 

Values (Default, ' 任 彩 萍 ', ' 人 才 招 聘 , 人 人 平等 ,机 会 难得 。'， 

Default, "招聘 规则 ') ; 


省 略 字 段 名 表 后 ,可 以 写成 下 列 语句 : 
Insert Into 论坛 /* 没 写字 段 名 表 , 按 表 中 的 字段 及 顺序 填写 值 * / 


Values (Default, '" 任 彩 萍 ', ' 人 才 招 聘 , 人 人 平等 ,机 会 难得 。'"， 
Default, "招聘 规则 ') ; 


创建 (Create Table ) 论 坛 表 时 (参照 例 4.3 和 例 4.8), 由 于 文章 序号 字段 具有 Auto_ 
Increment 属性 ,更 新 时 间 字 段 的 数据 类 型 为 TimeStamp, 因 此 ,增加 记录 时 ,文章 序号 字段 
的 值 由 系统 自动 编号 ,更 新 时 间 字 段 由 系统 填写 当时 的 日 期 时 间 。 

【 例 4.12】 参考 例题 4.2 .4.6 和 4.7, 在 公司 表 中 增加 3 个 数据 记录 。 


Insert Into 公司 表 (公司 名 称 , 地 址 ,注册 日 期 ,注册 人 数 ,简介 , 邮政 编码 ,注销 ,宣传 片 ) 
Values ("工商 前 进 支行 ', ' 长 春 市 高 新 区 ', "1991 -10 了 工 '，Default ,Null, 

'130012', Default, Null), /* 第 一 个 记录 结束 * / 
("腾飞 总 公司 ',' 北 京 市 中 关 村 ','2001 -7 二 ',2000，, Null, '100201', Default, Null)，, 
("医大 一 院 ', "长 春 市 朝阳 区 ', "1948 -1 了 1',5000, Null, '130012', Default, Null) 
/* 增加 多 个 记录 时 ,每 个 记录 的 值 都 要 用 小 括号 括 起 来 ,记录 之 间 用 逗号 分 隔 * / 
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由 于 公司 表 中 注册 人 数字 段 的 默认 值 是 100 ,注销 字段 默认 值 是 0( 假 ) ,因此 ,增加 
的 第 一 个 记录 中 注册 人 数字 段 对 应 表达 式 为 Default ,表示 100;3 个 记录 的 注销 字段 对 应 
的 表达 式 都 为 Default, 均 表示 0。 另 外 ,由 于 简介 和 宣传 片 两 个 字段 均 可 以 空 , 因 此 ,对 应 
表达 式 用 Null 表示 。 


5. 自动 填写 的 字段 


在 Insert Into 语句 的 字段 名 表 中 ,可 以 不 写 有 默认 值 (Default)、 自 增值 (Auto_ 
Increment) 允许 空 (Null) 或 时 间 截 类 型 (TimeStamp ) 的 字段 ,这 些 字段 由 系统 自动 填 值 。 
具体 处 理 方法 是 : 有 默认 值 的 字段 用 默认 值 填写 ; 自 增值 字段 用 自动 编号 填写 ;时 间 戳 字 
段 用 系统 当时 日 期 时 间 填 写 ; 其 他 允许 空 的 字段 用 Null 填写 。 

【 例 4.13】 向 公司 表 中 增加 “ 食 府 快餐 店 ” 的 数据 记录 。 

Insert Into 公司 表 (公司 名 称 ,地 址 ,注册 日 期 ,邮政 编码 ) 

Values(' 食 府 快餐 店 ', "长春 经 济 开 发 区 ',CurDate (), '130103'); 

在 语句 中 没有 描述 注册 人 数 ,简介 ,注销 和 宣传 片 4 个 字段 及 其 对 应 的 表达 式 , 但 实 
际 在 增加 的 数据 记录 中 ,注册 人 数字 段 填 成 100( 默 认 值 ) ,注销 字段 填 成 0( 默 认 值 ) 。 简 
介 和 宣传 片 两 个 字段 既 没 有 默认 值 , 也 不 是 自 增值 或 时 间 截 字段 ,但 是 ,允许 Null ,因此 ， 
二 者 均 用 Null 填写 。 公 司 表 中 新 增加 的 记录 如 表 4-2 所 示 。 


表 4-2 公司 表 中 增加 的 记录 














公司 名 称 地 址 注册 日 期 “| 注册 人 数 | 简介 | 邮政 编码 | 注销 | 宣传 片 
工商 前 进 支行 | 长 春 市 高 新 区 1991-10-01 100 Null 130012 0 Null 
腾飞 总 公司 北京 市 中 关 村 2001-07-01 2000 Null 100201 0 Null 
医大 一 院 长 春 市 朝阳 区 1948-01-01 5000 Null 130012 0 Null 
食 府 快餐 店 长 春 经 济 开发 区 | 2016-07-01 100 Null | 130103 | 0 Null 























6. On Duplicate Key Update 


当 新 增加 的 数据 记录 与 表 中 已 有 记录 的 关键 字 重 值 时 (例如 ,重复 执行 例 4.13 中 的 
语句 ) ,系统 将 出 现 错误 ,并 终止 执行 该 语句 。 如 果 在 语句 中 加 On Duplicate Key Update… 
短语 , 则 可 以 避免 出 错 ,并 且 能 修改 该 短语 之 后 各 个 字段 的 值 。 

【 例 4.14】 在 公司 表 中 增加 关于 “工商 前 进 支 行 ” 的 数据 记录 ,如 果 表 中 已 经 存在 
该 记录 , 则 只 修改 其 注册 人 数 和 简介 两 个 字段 的 值 。 

Insert Into 公司 表 (公司 名 称 , 地 址 ,注册 日 期 ,注册 人 数 ,简介 , 邮政 编码 ,注销 ,宣传 片 ) 

Values (' 工 商 前 进 支行 ', ' 长 春 市 高 新 区 建 业 大 厦 ','1991 -10 了 工 ' ,20 ， 
"于 2010 年 新 迁 入 高 新 区 。'， '130012'， Default, Null1) 
On Duplicate Key Update 注册 人 数 辽 0, 简 介 =' 于 2010 年 新 迁 入 高 新 区 。'; 


公司 表 中 关键 字 是 公司 名 称 字段 ,由 于 要 增加 的 “工商 前 进 支 行 " 记 录 在 表 中 已 经 存 
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在 (参考 表 4-2) ,因此 ,执行 这 条 语句 时 ,只 修改 了 On Duplicate KeyUpdate 短语 之 后 的 注 
册 人 数 和 简介 字段 的 值 ,而 不 会 将 原 地 址 由 “长 春 市 高 新 区 " 改 为 “长 春 市 高 新 区 建 业 
夫 厦 ”。 


7. 参照 完整 性 对 增加 记录 表 顺 序 的 制约 


对 具有 参照 完整 性 的 各 个 表 , 在 向 子 表 中 输入 数据 记录 之 前 ,应 该 先 向 父 表 中 输入 相 
关联 的 记录 。 即 ,系统 限制 向 子 表 中 输入 与 父 表 无 关联 的 记录 。 

【 例 4.15】 结合 第 2 章 中 的 表 2-11 ~ 表 2-13 的 结构 说 明 , 将 表 2-8( 岗位 表 ) . 表 2-6 
(应 聘 人 员 表 ) 和 表 2-7( 岗位 成 绩 表 ) 中 的 相关 列 转换 成 编码 后 分 别 存储 到 GWB .YPRYB 
和 GWCJB 中 。 

根据 创建 表 时 设置 的 表 之 间 的 关联 及 其 参照 完整 性 (参照 例 4.5) ,GWB 和 YPRYB 
均 为 CWCJB 的 父 表 ,因此 ,在 增加 GWCJB 中 的 数据 记录 之 前 ,应 该 先 填 加 GWB 和 
YPRYB 中 的 数据 记录 ,其 语句 如 下 : 


Insert Into GWB (岗位 编号 ,岗位 名 称 ,最 低 学 历 ,最 低 学 位 ,人 数 ,年 龄 上 限 ,年 薪 ， 
笔试 成 绩 比 例 , 笔 试 日 期 ,聘任 要 求 ,公司 名 称 ) 
Values ('A0001', ' 行 长 助理 ','3','2',1,24,8,70,'2017.1.14', 
"有 驾照 ,笔试 经 济 学 + 金融 ' 工 商 前 进 支行 ')， 
("A0002', "银行 柜员 ','2",'1',5,24,7,70, '2017.1.15"', 
"计算 机 二 级 ,笔试 : 金融 4 会 计 学 … "工商 前 进 支行 )， 
("B0001 ' 经 理 助理 ','5','5',1,30,12,50, '2017.1.14', 
"笔试 : 经 济 学 + 人 力 资源 ', "腾飞 总 公司 ")， 
("B0002', ' 理 财 师 ','3','2',10,35,9,70, '2017.1.15'， 
' 笔 试 : 经 济 法 圳 务 管理 ', "腾飞 总 公司 '); 


Insert YPRYB (身份 证 号 ,姓名 , 婚 否 ,最 后 学 历 ,最 后 学 位 ,所 学 专业 ,通信 地 址 ， 
邮政 编码 ,Email 账号 ,QQ 账号 ,固定 电话 ,移动 电话 ,密码 ,个 人 简历 ) 
VALUES 
("229901199503121538… '" 刘 德 厚 ',0,'3','2',' 会 计 学 '， 
' 长 春 前 进 大 街 2699 号 ','130012','ldh@jlu.edu.cn', 
'2408522733', "0431 -85166032', '13988699912"','1234", 
"2013 年 9 月 高 中 ……;2015 年 通过 全 国 计 算 机 考试 二 级 。')， 
("119801199210011321', ' 王 丽 敏 ',0,'4','4', ' 金 融 学 '， 
"北京 西城 区 德 外 大 街 4 号 '，"'100120"', "wlm@sina.com', 
'1908530753', "010 -58581603', '15888990157', '5678", 
"2010 年 9 月 高 中 …… ;2013 年 通过 全 国 计 算 机 考试 三 级 。'); 


执行 上 述 两 条 语句 后 ,才能 执行 下 列 向 子 表 GWCJB 中 增加 记录 的 语句 : 


Insert GHCJB ”/* 没 写字 段 名 表 , 按 表 中 的 字段 及 顺序 填写 值 * / 

Values ('229901199503121538', "A0002',1,80,85), 
("229901199503121538", 'B0002',1,90,85)， 
("119801199210011321", 'A0001',1,75,90); 
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4.5.2 增加 一 个 记录 


在 MySQL 中 ,执行 一 条 Insert … Values … 语句 可 以 增加 多 个 记录 ( 当然 ,也 可 以 只 
增加 一 个 记录 ) 。 但 是 ,执行 一 条 Insert … Set … 语句 只 能 增加 一 个 记录 。 
语句 格式 : 
Insert [Delayed ILow Priority IHigh Priority] 
[Into] < 表 名 Set < 他 段 各 1>=< 表 达 式 1 习 … 
[, 舍 段 名 n>=< 表 达 式 n 习 
[On Duplicate Key Update < 他 段 名 1 >=< 表 达 式 1>… 
[, 字段 名 m>=< 表 达 式 m>]] 
此 语句 的 主要 特点 是 : 运行 一 次 增加 一 个 数据 记录 ,并 且 ,字段 与 表达 式 的 对 应 关系 
比较 明确 ,比较 适合 填写 记录 中 部 分 字段 的 值 。 其 他 相关 规定 和 作用 同 Insert…Values… 
语句 。 


【 例 4.16】 在 GWCJB 中 添加 一 个 应 聘 人 员 申 报 记 录 。 


Insert GWCJB Set 身份 证 号 ='119801199210011321'" ,岗位 编号 ="B0001' 
/* 没 写 的 字段 按 默 认 值 填写 * /; 


语句 中 没有 描述 的 字段 资格 审核 ,笔试 成 绩 和 面试 成 绩 均 填写 默认 值 0。 
4.5.3 替换 数据 记录 


替换 数据 记录 的 语句 与 Insert 语句 类 似 ,也 分 一 次 操作 一 个 和 多 个 记录 两 种 语句 
格式 。 
语句 格式 1: 
Replace [Delayed |Low_Priority IHigh Priority] 
[Into] < 表 名 >[( 舒 段 名 表 习 ] 
Values ( < 表达 式 表 1 > … [, (表达 式 表 n>)] 
语句 格式 2: 
Replace [Delayed |Low_ Priority IHigh Priority] 
[Into] < 表 名 >Set 守 段 名 1>=< 表 达 式 1)… 
[, 和 守 段 名 n>=< 表 达 式 n 习 
执行 此 类 Replace 语句 时 ,如 果 要 增加 的 记录 与 表 中 已 有 记录 的 关键 字 重 值 , 则 不 增 
加 记录 ,而 用 语句 中 表达 式 的 值 蔡 换 原 记 录 对 应 字段 的 值 ; 反 之 , 则 新 增加 记录 ,用 表达 式 
的 值 填 写 新 记录 对 应 字段 的 值 。 
与 Insert 语句 不 同 , Replace 语句 不 会 因为 关键 字 重 复 而 出 错 , 也 不 需要 On Duplicate 
Key Update 短语 修改 部 分 字段 的 值 ,自身 能 用 表达 式 修改 语句 中 所 描述 的 字段 值 。 
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【 例 4.17】 在 GWCJB 中 ,对 身份 证 号 为 119801199210011321, 岗位 编号 为 B0001 
的 记录 ,资格 审核 字段 填 1( 审 核 通过 ) ,笔试 成 绩 字段 填 85 ,面试 成 绩 字段 填 80 ,同时 增 
加 申报 岗位 B0002 的 记录 。 
Replace GWCJB ”/* 没 写字 段 名 表 , 按 表 中 的 字段 及 顺序 填写 值 * / 
Values ("119801199210011321", "B0001",1, 85, 80), 
("119801199210011321", "B0002" ,Default, Default, Default); 


执行 此 语句 后 ,在 GWCJB 中 实际 修改 了 第 一 个 记录 (参考 例 4.16) ,增加 了 第 二 个 
记录 。 


4.6 数据 维护 


数据 维护 主要 指 修改 ( Update) 和 删除 (Delete From) 表 中 的 数据 记录 。 在 修改 或 删除 
表 中 的 部 分 数据 记录 时 ,需要 说 明 要 操作 哪些 记录 , 即 , 明 确 被 操作 记录 的 条 件 ,这 里 的 
“条 件 " 实 质 是 一 个 逻辑 值 ( 真 或 假 ) 表 达 式 。 


4.6.1 逻辑 值 表 达 式 


逻辑 值 表达 式 是 值 为 真 或 假 的 表达 式 , 主要 用 于 事务 的 是 非 判 断 和 数据 分 析 。 在 
MySQL 中 ,用 数值 型 数据 0 和 非 0 表示 逮 辑 型 数据 ,0 为 False( 假 ) , 非 0 为 True( 真 )。 通 
常 在 输入 逻辑 型 数据 时 ,人 们 习惯 将 假 输 入 为 0, 真 输入 为 1 ,系统 输出 逻辑 值 时 也 是 如 此 
处 理 。 

风 辑 值 表达 式 与 普通 表达 式 一 样 ,可 以 是 常数 (0 或 False 为 假 , 非 0 或 True 为 真 )、 
变量 (字段 ) 和 函数 。 通 过 比较 运算 符 ( 关 系 表达 式 ) . 迎 辑 运算 符 ( 逻 辑 表达 式 ) .谓词 运 
算 符 和 逻辑 值 函 数 可 以 构造 更 复杂 的 迎 辑 值 表达 式 , 其 运算 结果 为 1( 真 ) 或 0( 假 ) 。 

在 SQL 语句 中 通常 将 逻辑 值 表达 式 称 为 条 件 表 达 式 ,也 简称 为 条 件 。 如 果 修 辑 值 表 
达 式 的 值 为 真 ( 非 0) , 则 称 满 足 或 符合 条 件 ;如 果 逻 辑 值 表达 式 的 值 为 假 (0) , 则 称 不 满 
足 或 不 符合 条 件 。 


1. 比较 运算 


比较 运算 符 分 为 以 下 两 类 : 

(1) 常规 比较 运算 符 。 有 =、<、< =(<)、> 和 >=( 三 ), < > 与 ! = 均 表示 不 等 
( 壮 )。 多 个 符号 组 成 的 运算 符 ( 如 < =、> = 和 < > 等 ) ,符号 之 间 不 能 加 空格 。 数 值 ( 逻 
辑 ) 型 数据 遵循 数学 中 规定 的 大 小 关系 ;日 期 (时 间 ) 型 数据 ,时 间 在 前 的 数据 小 。 运 算 项 
之 一 或 两 项 均 为 Null 时 ,运算 结果 为 Null, 而 不 是 0 或 1。 例如 ,5 >3 的 值 为 1,CurTime( ) 
=Time( Now( ) ) 的 值 为 1,5 > Null 的 值 为 Null。 

(2) 含 Null 等 值 运算 符 。< = >。 与 = 的 区 别 仅 在 于 含 Null 运算 项 。 < = > 运算 


项 之 一 是 Null 时 ,结果 是 0; 两 项 均 为 Null 时 ,结果 是 1,。 例如 ,' InterNet' < = > ' 互 联网 ' 
的 值 为 0,5 < = > Null 的 值 为 0,Null < = > Null 的 值 为 1, 而 Null = Null 的 值 为 Null。 
比较 运算 的 规则 如 下 : 

(1) 字符 串 型 数据 的 比较 规则 。 比 较 两 个 字符 串 型 数据 的 总 体 规则 是 去 掉 各 自 的 尾 
部 空格 后 自 左 向 右 按 对 应 字符 进行 比较 。 如 果 比 较 到 某 位 字符 不 等 , 则 包含 小 字符 的 字 
符 串 较 小 ;如 果 比 较 到 较 短 字 符 串 的 末尾 还 没 比较 出 大 小 关系 , 则 短 字符 串 较 小 ;如 果 两 
个 字符 串 完 全 相同 , 则 运算 结果 相等 。 单 个 字符 比较 规则 为 : '0' < '1' < … <'9' <'A' 
<'B' … <'Z' ,英文 字母 不 区 分 大 小 写 , 即 'A' ='a' … 'Z' ='z' ;英文 字母 小 于 汉字 。 例 
如 ,2' >'10' .AL' > '999' 和 ' 阿 ' > 'ZX' 的 值 均 为 1; InterNet = ' 互 联网 ' 的 值 为 0。 

(2) 不 同类 型 数据 的 比较 。 对 不 同类 型 的 数据 进行 比较 时 ,系统 将 两 个 运算 项 的 数 
据 类 型 转换 一 致 后 再 进行 比较 。 常 用 数据 类 型 的 转换 与 比较 规则 如 下 : 

。 数值 (逻辑 ) 型 与 其 他 类 型 数据 比较 。 数 据 项 之 一 是 数值 (人 逻辑) 型 , 另 一 项 为 字 

符 串 或 日 期 (时 间 ) 型 时 ,转换 另 一 项 为 数值 (逻辑 ) 型 后 再 进行 比较 。 例 如 ,10 > 
'2' 和 '5 元 ' <15 的 值 均 为 1( 转 换 成 10 >2 和 5 <15, 真 ) ,而 '10' >'2’ 和 '5 元 ' < 
15 的 值 均 为 0( 假 ) ;CurDate( ) >3000 的 值 为 1 ,假如 系统 日 期 为 2018 年 3 月 31 
日 , 则 将 CurDate( ) 的 值 转换 为 数值 20180331 后 再 与 3000 比较 。 

。 字 符 串 型 与 日 期 (时 间 ) 型 数据 比较 。 日 期 (时 间 ) 型 自动 转换 成 字符 串 型 数 
据 后 再 进行 比较 。 例 如 ,CurDate( ) >'3000' 的 值 为 0 ,实质 是 将 CurDate( ) 的 
值 转换 成 格式 为 YYYYMMDD 的 字符 串 型 数据 (如 '20180331' ) 后 再 与 '3000 
' 比 较 。 


2. 逻辑 运算 


逻辑 运算 主要 有 以 下 3 种 : 

(1) 取 反 ( 非 ) 运 算 : | Notl1| < 迎 辑 值 表达 式 > 。 运 算 结果 与 逻辑 值 表达 式 的 值 相 
反 (0\1 互 变 )。 例 如 ,15 >3 的 值 为 0,Not 'InterNet = ' 互 联网 ' 的 值 为 1,! 最 后 学 历 = '0' 
与 最 后 学 历 ! = '0' 的 值 一 致 

(2) 与 (并 且 ) 运 算 : < 届 辑 值 表达 式 1 > | Andl&& | < 则 辑 值 表达 式 2 > 。 如 果 两 
个 逻辑 值 表达 式 的 值 均 为 真 ( 非 0) , 则 运算 结果 为 1 ,否则 ,运算 结果 为 0。 例 如 ,5 >3 
And 'InterNet' = ' 互 联网 ' 的 值 为 0,Now( ) =SysDate( ) && CurTime( ) = Time(Now( ) ) 的 
值 为 1。 

(3) 或 运算 : < 逻辑 值 表达 式 1 > | Or 或 11 | < 逻辑 值 表达 式 2 > 。 如 果 两 个 逻辑 
值 表达 式 的 值 均 为 假 (0) , 则 运算 结果 为 0 ,否则 ,运算 结果 为 1。 例如 ,5 >3 Or 'InterNet 
= ' 互 联网 ' 的 值 为 1,CurDate() =Now() 11 CurDate() =SysDate( ) 的 值 为 0。 

其 他 类 型 作为 逻辑 型 数据 使 用 时 , 先 将 其 他 类 型 的 数据 转换 成 数值 ,转换 结果 非 0 为 
真 ,0 为 假 。 例 如 ,'5 元 ' Or ' 计 算 机 ' 和 '5 元 ' And CurDate( ) 的 值 均 为 1,'5 元 ' And ' 计 
算 机 ' 的 值 为 0( 因 ' 计 算 机 ' 转 换 结 果 为 0) 。 
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3. 谓词 运算 

谓词 是 实现 较 复杂 数据 分 析 判 断 的 一 种 运算 符 , 适 当 使 用 谓词 运算 符 ,可 以 简化 逻辑 
值 表达 式 , 甚 至 可 以 完成 比较 运算 无 法 实现 的 任务 。 有 以 下 5 种 常用 的 谓词 运算 。 

(1) 区 间 判 断 运算 格式 : 

X Between Y And Z 

Between 运算 功能 等 效 于 X> =Y And X < =Z。 

例如 ,车 0<X<9, 则 X Between 0 And 9 的 值 为 1; 若 X 值 中 首 字符 为 英文 字母 ( 如 
'B2' 'e 指数 ' 等 ) , 则 X Between 'A' And 'Z' 的 值 为 1。 此 运算 符 适 用 于 某 个 数据 区 间 的 
判断 。 

【 例 4.18】 输出 1980 年 到 2000 年 出 生 的 应 聘 人 员 信 息 。 

Select * From YPRYB Where Mid (身份 证 号 ,7,4) Between 1980 And 2000 

(2) Null 、 真 或 假 的 判断 运算 格式 : 

XIs [Not] { Null |True IFalse } 

用 于 判断 表达 式 X 的 值 是 否 为 Null .True( 真 ) 或 False( 假 ) ,运算 结果 为 1 或 0。 例 如 ， 
5 Is Not True 的 值 为 0;0 Is False 的 值 为 1;" Is Not Null 的 值 为 1( 说明 空 字 符 串 不 是 Null) 。 
常用 于 判断 表达 式 的 值 为 Null 、 真 或 假 , 如 笔试 成 绩 I Null ,资格 审核 Is True 等 。 

【 例 4.19】 输出 公司 表 中 还 没有 宣传 片 的 公司 信息 和 GWCJB 表 中 已 经 通过 资格 审 
核 的 申报 信息 。 


Select * From 公司 表 Where 宣传 片 Is Null; 


Select * From GWCJB Where 资格 审核 Is True; 

(3) 成 员 判 断 运算 格式 : 

X [Not] In(X, [,%* ,X,]) 

若 存 在 X;(1<i<n) ,使 得 X=X;, 则 In 运算 结果 为 1 ,否则 ,运算 结果 为 0。In 运算 
等 效 于 表达 式 X=X,[ Or X =X,… OrX=X,]。 例 如 ,互联 网 ' m (' 计 算 机 ' ,' 数 据 库 ' ， 
' 互 联网 ' ) 的 值 为 1。 常 用 于 集合 中 的 成 员 判 断 , 如 工作 日 (周一 ~ 周 五 ) 判断 , WeekDay 
(CurDate( ) ) In (0,1,2,3,4) ;学 历 判断 ,最 后 学 历 In('2' ,'3' ,'4' ) 等。 

【 例 4.20】 输出 学 士 (编码 为 2) ,硕士 (编码 为 4) 或 博士 (编码 为 5) 学 位 的 应 聘 人 
员 信 息 。 

Select * From YPRYB Where 最 后 学 位 In ('2', '4','5') 

(4) 匹配 运算 的 运算 格式 : 

字符 串 表 达 式 1 >[Not] Like 六 符 串 表达 式 2 > 
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如 果 两 个 字符 串 匹配 , 则 Like 运算 结果 为 1( 真 ) ,否则 ,运算 结果 为 0( 假 ) 。 

在 字符 串 表 达 式 2 的 值 中 可 以 包含 匹配 符号 百 分 号 “%” 和 下 夯 线 “_”。“% "表示 其 
位 置 的 任意 多 个 字符 或 汉字 (甚至 可 以 没有 ) ;“_" 则 表示 其 位 置 的 一 个 字符 或 汉字 。 例 
如 ,' 李 大 明 ' Like ' 李 %' ) 和 (' 李 大 明 ' Like ' 李 __' ) 的 值 均 为 1, 而 (' 李 大 明 ' Like ' 李 _ 
' ) 的 值 为 0。 

(5) 选择 匹配 运算 的 运算 格式 : 

< 他 符 串 表达 式 1 >[Not] {RLike IREGEXP} < 他 符 串 表达 式 2 > 

RLike 与 REGEXP 功能 相同 。 字 符 串 表达 式 2 中 值 的 字符 串 格式 为 : < 子 串 , > [1 < 
子 串 ，> ……: 1 < 子 串 , > ] , 即 , 各 个 子 串 之 间 用 竖 线 “ 1" 分隔。 

如 果 有 子 串 ,(1<i<n) 出 现在 字符 串 表 达 式 1 的 值 中 , 则 RLike 和 REGEXP 运算 结 
果 为 1( 真 ); 如 果子 串 , 到 子 串 ,都 没有 出 现在 字符 串 表 达 式 1 的 值 中 , 则 RLike 和 
REGEXP 运算 的 结果 为 0( 假 ) 。 

【 例 4.21】 输出 公司 地 址 中 包含 北京 .上海 或 深圳 的 公司 信息 。 

Select * From 公司 表 Where 地 址 RLike ' 北 京 | 上 上海 深圳 ' 

功能 等 效 于 : 


Select * From 公司 表 /* Select 为 输出 表 中 记录 的 SQL 语句 * / 
Where 地 址 Like '$ 北 京 $' Or 地 址 Like '% 上 海 $' Or 地 址 Like '% 深 圳 和 %' 


4. 分 支 运 算 

分 支 运 算是 依据 条 件 不 同 从 若干 个 表达 式 中 选取 一 个 表达 式 值 的 运算 。 有 以 下 两 种 
常用 的 分 支 运 算 。 

(1) 多 分 支取 值 运算 格式 : 

Case X When Y, Then 7Z,*… When Y, Then Z, [Else 7, ] End 


从 六 到 六 ,依次 找 等 于 X 的 Yi , 若 找到 Yi , 则 计算 结果 为 Zi。 若 没 找到 Yi , 当 有 Else 
Zu 时 ,计算 结果 为 Z,,,; 当 没有 Else Z,,, 时 ,计算 结果 为 Null。 
【 例 4.22】 输出 当前 系统 日 期 对 应 的 周 几 中 文 名 。 
Select Case WeekDay (CurDate) When 0 Then ' 周 一 ' 
When 1 Then ' 周 二 ' When 2 Then ' 周 三 ' When 3 Then ' 周 四 ' 
When 4 Then ' 周 五 ' When 5 Then ' 周 六 ' Else ' 周 日 ' End 
其 中 Select 为 输出 表达 式 值 的 语句 。 
(2) 多 条 件 取 值 运算 格式 : 


Case When 条件 ， AThen 2 … When < 条 件 。 >Then Z, [Else Zu] End 


从 条 件 , (逻辑 值 表达 式 ) 到 条 件 ,进行 判断 ,车 条 件 ;(1<i<n) 成 立 ( 值 非 0) , 则 计算 
结果 为 Z,。 若 所 有 条 件 都 不 成 立 , 当 有 Else Z, ,时 ,计算 结果 为 Z,,,; 当 没有 Flse Z, ,1 时， 
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计算 结果 为 Null。 
【 例 4.23】 输出 GWCJB 中 的 身份 证 号 .岗位 编号 和 笔试 成 绩 的 等 级 : 90 及 以 
上 为 优秀 ;小 于 90 且 大 于 等 于 80 为 良好 ;小 于 80 且 大 于 等 于 60 为 合格 ,否则 为 不 
合格 。 
Select 身份 证 号 ,岗位 编号 ， 
Case When 笔试 成 绩 >-90 Then ' 优 秀 ' When 笔试 成 绩 >-80 Then ' 良 好 ' 
When 笔试 成 绩 >=60 Then ' 合 格 ' Else ' 不 合格 ' End 
From GWCJB 
两 个 分 支 运 算 的 主要 区 别 在 于 : 前 者 适用 于 确定 若干 个 点 ( 枚 举 ) ,而 后 者 适用 于 确 
定 若干 个 数据 范围 (条 件 ) 。 


5. 相关 函数 


(1) IsNull(X) 函数 : 如 果 X 的 值 为 Null, 则 ENull 函数 返回 值 为 1, 否则 ,返回 值 
为 0。 
【 例 4.24】 输出 公司 表 中 还 没有 宣传 片 的 公司 信息 。 


Select * From 公司 表 Where IsNull 人 宣传 片 ) ; 


与 [ 例 4.19】 输 出 的 公司 信息 完全 相同 ,设计 差别 仅 在 于 本 例 使 用 IsNull 函数 ,而 
【 例 4.19] 使 用 Is Null 运算 。 

(2) (X,Y,Z): 分 支 函数 。 如 果 XX 的 值 为 真 ( 非 0) , 则 函数 返回 Y 的 值 ,否则 , 返 
回 Z 的 值 。 

【 例 4.25】 输出 应 聘 人 员 的 身份 证 号 .姓名 和 性 别 。 

Select 身份 证 号 ,姓名 ,If (Mod (Mid (身份 证 号 ,17,1) ,2) 改 , ' 女 ',' 男 ') From YPRYB 

(3) IINul(X,Y) : Null 分 支 函 数 。 如 果 X 的 值 是 Null, 则 函数 返回 Y 的 值 ,否则 , 返 
回 X 的 值 。 

【 例 4.26】 输出 公司 表 中 公司 名 称 、 地 址 和 注册 日 期 (没有 注册 日 期 时 输出 “日 期 
待定 ” ) 。 

Select 公司 名 称 , 地 址 ，IfNull (注册 日 期 ，' 日 期 待定 ') From 公司 表 








4.6.2 修改 数据 记录 


执行 Update 语句 可 以 自动 修改 满足 某 条 件 一 批 记 录 的 相关 字段 值 ,执行 此 语句 的 用 
户 必 须 具 有 Update 权限 。 
语句 格式 : 
Update [Low Priority] < 表 名 列表 >Set 和 守 段 名 1>=< 表 达 式 1 >… 
[, 人 守 段 名 n>=< 表 达 式 n >][ Where 订 件 表达 式 
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(1) 表 名 列表 。 用 于 指出 同一 条 语句 中 要 修改 的 各 个 表 名 ,由 于 修改 多 个 表 中 同名 
字段 值 的 情况 非常 少见 ,在 绝 大 多 数 应 用 中 ,一 条 语句 只 修改 一 个 表 中 的 数据 记录 ,因此 ， 
表 名 列表 通常 只 写 一 个 表 名 。 

(2) 表达 式 i。 用 表达 式 i 的 值 修 改 对 应 字段 的 值 。 为 了 清空 某 字段 的 值 ,对 应 表达 
式 可 以 用 Null 表示 ,但 设计 表 结 构 时 ,该 字段 必须 允许 为 Null。 

(3) 条 件 表达 式 。 如 果 省 略 Where 短语 , 则 修改 表 中 全 部 记录 相关 字段 的 值 ;如 
果 使 用 Where < 条件 表达 式 > 短语 , 则 只 修改 满足 条 件 的 那些 记录 中 相关 字段 





的 值 。 

【 例 4.27】 对 笔试 或 面试 成 绩 低 于 60 分 的 申报 记录 ,资格 审核 字段 的 值 填 成 未 通 
过 (0%s 

Update GWCJB Set 资格 审核 -0 /* 设 为 资格 审核 没 通过 * / 


Where 笔试 成 绩 <60 Or 面试 成 绩 <60; 
【 例 4.28】 对 腾飞 总 公司 的 每 个 岗位 ,笔试 日 期 延 后 7 天 ,增加 2 人 。 


Update WB 
Set 笔试 日 期 qdDate (笔试 日 期 ,7) ,人数 = 人 数 世 。” /*# 调 整 笔试 日 期 和 人 数 * / 
Where 公司 名 称 =" 腾 飞 总 公司 '; 


【 例 4.29】 将 公司 表 中 空 简 介 字 段 的 值 改 为 “正在 完善 中 …… wo 
Update 公司 表 Set 简介 =' 正 在 完善 中 …… ' Where 简介 Is Null; 
【 例 4.30】 将 公司 名 中 含 “工商 "和 *“ 行 " 字 的 所 有 岗位 年 薪 增 加 10% 。 


Update GWB Set 年 薪 年薪 * (1 #10 / 100) /* 年 薪 调 整 为 原 年 薪 的 1.1 倍 */ 
Where 公司 名 称 Like '$ 工 商 $' And 公司 名 称 Iike'"s 行 %"; ”/* 用 谓词 运算 * / 


4.6.3 删除 数据 记录 


通过 Delete 语句 ,可 以 删除 满足 某 条 件 的 一 些 记 录 ,也 可 以 无 条 件 地 删除 表 中 的 全 部 
记录 ,使 之 成 为 空 表 。 执 行 删除 数据 记录 语句 的 用 户 必须 具有 Delete 权限 。 

语句 格式 : 

Delete [Low Priority] [Quick] From < 表 名 >[Where < 条 件 表达 式 习 

当 省 略 Where 短语 时 ,将 删除 表 中 的 全 部 记录 ; 当 使 用 Where < 条件 表达 式 > 
时 , 仅 删除 满足 条 件 的 那些 记录 。 在 语句 中 使 用 Quick 短语 可 以 缩短 语句 的 执行 


时 间 。 
【 例 4.31】 删除 论坛 表 中 的 所 有 记录 和 GWCJB 表 中 没有 通过 资格 审核 的 记录 。 
Delete Quick From 论坛 ; /* 无条件 删除 论坛 中 的 所 有 记录 * / 


Delete From GWCJB Where Not 资格 审核 ; /* 删除 GWcoB 中 资格 审核 值 为 0 的 记录 */ 
由 于 资格 审核 字段 是 逻辑 型 ,因此 ,将 * Where Not 资格 审核 "写成 “Where 资格 审核 = 
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0”" 或 “Where 资格 审核 Is False” 效 果 相 同 。 


4.6.4 参照 完整 性 对 数据 维护 的 影响 


对 设置 了 参照 完整 性 的 表 修改 关联 字段 的 值 ,或 者 删除 父 表 中 的 数据 记录 时 ,由 于 限 
制 和 级 联 约束 规则 的 作用 ,可 能 导致 同时 连锁 修改 或 删除 多 个 表 中 的 数据 记录 ,也 可 能 导 
致 限制 删除 或 修改 某 些 数据 记录 。 


1.“ 级 联 " 对 数据 维护 的 影响 


在 表 之 间 的 参照 完整 性 “级 联 "( On Update Cascade 和 On Delete Cascade) 的 影响 下 ， 
修改 父 表 中 关联 字段 的 值 时 ,将 自动 修改 子 表 中 关联 记录 对 应 外 键 字段 的 值 ;删除 父 表 中 
的 数据 记录 时 ,将 自动 删除 子 表 中 与 之 关联 的 记录 。 

【 例 4.32】 在 YPRYB 表 中 ,将 身份 证 号 119801199210011321 改 为 11980119921001132X， 
同时 删除 身份 证 号 为 229901199503121538 的 记录 。 


Update YPRYB Set 身份 证 号 ='11980119921001132X ' 
Where 身份 证 号 ="'119801199210011321'; 
/* 同时 修改 GWCOB 中 身份 证 号 为 119801199210011321 的 所 有 记录 * / 


Delete From YPRYB Where 身份 证 号 ='229901199503121538"'; 
/* 同时 删除 GWcJB 中 身份 证 号 为 229901199503121538 的 全 部 记录 * / 


根据 例 4.5,YPRYB 与 GWCJB 之 间 参 照 完 整 性 的 更 新 (修改 ) 和 删除 约束 规则 均 是 
级 联 (Cascade) ,因此 ,在 YPRYB( 父 表 ) 中 修改 关联 字段 (身份 证 号 ) 的 值 或 删除 数据 记 
录 , 均 会 连锁 操作 GWCJB( 子 表 ) 中 的 关联 记录 。 即 , 随 着 YPRYB 中 身份 证 号 (关联 字 
段 ) 由 119801199210011321 改 为 11980119921001132X,GWCJB 中 相关 联 记录 的 身份 证 号 
(外 键 字 段 ) 也 自动 由 119801199210011321 变 为 11980119921001132X; 同样 ,删除 YPRYB 
中 身份 证 号 为 229901199503121538 的 记录 ,也 引起 连锁 删除 GWCJB 中 身份 证 号 为 
229901199503121538 的 全 部 记录 。 


2.“ 限 制 " 对 数据 维护 的 影响 


在 表 之 间 的 参照 完整 性 为 “限制 ”( On Update No Action | Restrict 和 On Delete No 
Action1Restrict) 的 影响 下 ,不 允许 修改 父 表 中 与 子 表 有 关联 记录 的 关联 字段 值 ; 也 不 允许 
删除 父 表 中 与 子 表 有 关联 的 记录 。 

【 例 4.33】 验证 参照 完整 性 “限制 "对 数据 维护 的 影响 。 

Update GWB Set 岗位 编号 ='C0001' Where 岗位 编号 ='B0001"'; 

/* 因 GWcJB ( 子 表 ) 中 有 岗位 编号 为 B9001 的 记录 ,执行 该 语句 失败 * / 


Delete From GWB Where 岗位 编号 ='"B0001'7 
/* 因 GWCOB ( 子 表 ) 中 有 岗位 编号 为 B9001 的 记录 ,执行 该 语句 失败 * / 
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根据 例 4.5,GWB 与 GWCJB 之 间 参 照 完 整 性 的 更 新 (修改 ) 和 删除 约束 规则 均 是 限 
制 (Restrict) ,由 于 GWCJB( 子 表 ) 中 存在 岗位 编号 为 B0001 的 记录 ,因此 ,不 能 将 GWB 
( 父 表 ) 中 岗位 编号 (关联 字段 ) 由 B0001 改 为 C0001 ,也 不 能 删除 GWB( 父 表 ) 中 岗位 编 
号 为 B0001 的 数据 记录 。 解 决 这 类 问题 的 一 种 方法 是 : 先 删除 GWCJB( 子 表 ) 中 的 关联 
记录 (如 Delete From GWCJB Where 岗位 编号 =“，B0001' ) ,再 执行 GWB( 父 表 ) 中 的 修改 
或 删除 语句 。 


3. 参照 完整 性 对 修改 子 表 中 外 键 字段 值 的 影响 


表 之 间 的 参照 完整 性 无 论 是 限制 (No Action 或 Restrict) 还 是 级 联 ( Cascade) , 子 表 中 
修改 后 的 外 键 字 段 值 都 必须 在 父 表 中 有 关联 的 记录 。 
【 例 4.34】 验证 参照 完整 性 对 修改 子 表 中 外 键 字 段 值 的 影响 。 
Update GWCJB Set 身份 证 号 ='119801199210011321 
Where 身份 证 号 ="11980119921001132X'; /*# 语句 执行 失败 * / 


Update GWCJB Set 岗位 编号 ='C0001' Where 岗位 编号 ='B0001'; /*# 语句 执行 失败 * / 


执行 这 两 条 语句 失败 的 原因 在 于 YPRYB ( 父 表 ) 中 找 不 到 修改 后 的 身份 证 号 为 
119801199210011321 的 记录 ,同样 ,在 GWB( 父 表 ) 中 也 没有 修改 后 的 岗位 编号 为 C0001 
的 记录 。 解 决 这 类 问题 的 办 法 是 : 在 父 表 中 先 增加 关联 的 记录 ,再 执行 上 述 修改 数据 的 
语句 即 可 。 


4.7 数据 查询 及 统计 分 析 


Select 语句 构成 了 SQL 的 数据 查询 语言 , 它 是 SQL 的 核心 内 容 ,通过 Select 语句 可 以 
从 一 个 或 多 个 数据 源 中 提取 数据 进行 数据 查询 .数据 源 连 接 和 统计 分 析 等 。 凡 是 具有 
Select 权限 的 用 户 都 可 以 执行 数据 查询 语句 。 

语句 格式 : 


Select [All | Distinct [Row]] [High Priority] 
[ 数据 源 别名 >.] * | < 表达 式 1 >[ [As] 有 列 名 1]… 
[, 表达 式 n>[[As] 刑名 n>]] 
From < 数据 源 名 1 >[[As] 牧 据 源 别 名 1 >]… 
[, 牧 据 源 名 m>[ [As] 效 据 源 别名 m>]] 
[Where < 条 件 表达 式 习 
[order By < 排序 关键 字 1 >[ASC IDESC]… 
[, < 排序 关键 字 n >[ASC IDESC]]] 
[Group By < 分 组 关键 字 1 >[ASC IDESC]… 
[, < 分 组 关键 字 n >[ASC IDESC]] [With Rollup]] 
[Having < 条 件 表达 式 习 
[Limit[ < 开始 行 号 >,] < 行 数 习 
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[Into OutFile < 文本 文件 名 >…] 


在 Select 语句 中 加 High_Priority 短语 ,可 以 提高 执行 数据 查询 语句 的 优先 级 ,加 快 数 
据 检索 的 速度 。 


4.7.1 数据 基本 查询 


Select 语句 的 完整 结构 比较 复杂 ,选项 众多 ,功能 非常 强大 。 是 否 选 用 某 些 选项 决定 
了 语 旬 的 具体 功能 和 运行 效率 。 数 据 基本 查询 是 从 数据 源 中 提取 相关 记录 及 数据 项 的 常 
用 而 简单 的 一 种 操作 形式 ,能 满足 数据 查询 的 一 般 性 应 用 要 求 。 


1.[ < 数据 源 别名 >. ] * | < 表达 式 i>[ [As] < 列 名 称 i>] 


数据 查询 结果 是 由 若干 行 和 列 组 成 的 表 , 由 “[ < 数据 源 别名 >. ] * 1 < 表达 式 i> 
[[As] < 列 名 称 i> ] ”确定 每 列 的 标题 和 数据 。 

(1) [ < 数据 源 别 名 > . ] * 。 表 示 查 询 结果 中 包含 对 应 数据 源 中 的 全 部 字段 ,如 果 
省 略 数据 源 别名 , 则 表示 查询 结果 中 包含 全 部 数据 源 中 的 所 有 字段 。 

(2) 表达 式 i。 系 统 将 按 表 达 式 i 提取 或 运算 第 i 列 的 数据 。 表 达 式 i 可 以 是 一 个 字 
段 名 ( 称 字段 列 ) ,也 可 以 是 通俗 意义 上 的 表达 式 ( 称 计算 列 ) 。 

【 例 4.35】 输出 GWB 中 的 全 部 字段 和 申报 各 岗位 人 员 的 身份 证 号 。 


Select GWB.* ,身份 证 号 From GWB, GWCJB Where GWB. 岗 位 编号 =-GWCJB. 岗 位 编号 ; 


其 中 ,“GWB. * ”表示 输出 结果 中 包含 CWB 中 的 全 部 字段 ,“GWB,GWCJB" 为 数据 
来 源 ,“GWB. 岗位 编号 =GWCJB. 岗位 编号 "是 两 个 表 的 连接 条 件 。 

(3) [As] < 列 名 称 i>。 为 查询 结果 的 第 i 列 定义 列 名 及 标题 ,命名 规则 与 表 中 字 
段 的 命名 规则 相同 。 省 略 此 项 时 ,表达 式 i 即 为 第 i 列 的 名 称 及 标题 。 当 表达 式 i 是 计算 
列 ( 非 字 段 列 ) 时 ,表达 式 作为 列 标题 含义 并 不 明确 ,用 户 不 易 理 解 , 应 该 为 其 定义 一 个 有 
代表 意义 的 列 标题 。 使 用 [ As] < 列 名 称 i> 时 ,可 以 省 略 As, 但 表达 式 与 列 名 称 之 间 至 
少 有 一 个 空格 。 

【 例 4.36】 输出 应 聘 人 员 的 身份 证 号 .姓名 .出 生日 期 和 性 别 。 

Select 身份 证 号 ,姓名 ,Mid (身份 证 号 ,7,8) 出 生日 期 ， 

If (mid (身份 证 号 ,17,1)% 2 -0，' 女 …' 男 ') as 性 别 From YPRYB; 

语句 中 定义 了 “出 生日 期 "和 “性 别 " 两 个 计算 列 。 用 Mid( 身份 证 号 ,7,8) 函数 从 身 
份 证 号 的 第 7 位 开始 取 8 位 得 到 出 生日 期 ,并 且 ,Mid( 身 份 证 号 ,7,8) 函数 与 “出 生日 期 ” 
之 间 省 略 了 As。 输 出 结果 如 表 4-3 示 。 

身份 证 号 的 第 17 位 是 偶数 表示 女性 ,是 奇数 表示 男性 ,因此 ,由 函数 [f( mid( 身份 证 
号 ,17,1) % 2=0,' 女 '， 男 ') 可 以 获得 申报 人 员 的 性 别 , 并 用 “As 性 别 " 定 义 了 列 名 称 及 
标题 ,输出 结果 如 表 4-3 所 示 。 其 中 ,身份 证 号 和 姓名 均 由 字段 名 充当 列 名 ,出 生日 期 和 
性 别 均 为 计算 列 。 
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表 4-3 定义 列 名 称 的 输出 结果 


























身份 证 号 姓名 出 生日 期 性 别 
1980119921001132X 王 丽 敏 19921001 支 
19901199001011351 郝 帅 19900101 男 
29901199305011524 李 丽 丽 19930501 去 
29901199305011575 赵 明 19930501 男 
29901199503121538 刘 德 厚 19950312 男 


2. From < 数据 源 名 i>[[As] < 数据 源 别 名 i> ] 


From < 数据 源 名 i>[[As] < 数据 源 别 名 i> ] 用 于 指定 查询 数据 的 来 源 , 即 从 哪里 
提取 要 操作 的 数据 。 查 询 数据 的 来 源 也 简称 数据 源 , 绝 大 多 数 情况 是 数据 表 , 有 时 也 用 
视图 。 

(1) [As] < 数据 源 别 名 i > 。 为 数据 源 另 起 别名 ,如果 不 起 别名 , 则 数据 源 名 即 为 数 
据 源 别名 。 数 据 源 别名 的 主要 作用 是 便于 语句 中 其 他 短语 或 子 句 中 引用 该 数据 源 中 的 数 
据 。 特 别 是 在 SQL 语句 的 黄 套 中 ,可 能 将 一 个 数据 源 同时 作为 主 和 子 语句 的 数据 源 ,应 
该 将 这 类 数据 源 另 起 别名 ,以 便 区 分 彼此 。 省 略 As 时 ,数据 源 名 与 别名 之 间 至 少 有 一 个 

(2) 多 个 数据 源 。 当 数据 来 源 于 多 个 数据 源 时 ,数据 源 名 之 间 用 半角 逗号 " ,” 分 隔 。 
在 一 条 SQL 语句 中 , 如 果 某 个 字段 名 来 源 于 两 个 或 更 多 数据 源 , 则 该 字段 名 前 应 该 加 
“< 数据 源 别 名 >.”, 例 如 , 例 4.35 中 的 “GWB. 岗位 编号 "和 “GWCJB. 岗位 编号 ”"。 如 果 
某 字段 名 只 是 一 个 数据 源 中 的 字段 , 则 可 以 不 写 * < 数据 源 别名 >.”。 例 4.35 和 例 4.36 
中 的 身份 证 号 和 姓名 字段 名 前 不 需要 写 ” < 数据 源 别名 >.”。 

数据 来 源 于 多 个 数据 源 时 ,数据 源 之 间 要 进行 连接 ,连接 条 件 写 在 Where < 条 件 表达 
式 > 中 ,例如 ,在 例 4.35 中 ,“GWB. 岗位 编号 =GWCJB. 岗位 编号 "就 是 GWB 与 GWCJB 
之 间 的 连接 条 件 。 


3. Where < 条 件 表达 式 > 


Where < 条件 表达 式 > 常用 于 设置 下 列 两 种 条 件 。 

(1) 提取 记录 的 条 件 。 根 据 数据 源 中 各 个 字段 的 值 ,设置 被 操作 记录 应 该 满足 的 条 
件 。 条 件 表 达 式 中 可 以 包含 字段 名 ,常数 和 普通 函数 ,但 不 能 使 用 As 定义 的 列 名 和 有 关 
数据 统计 函数 (如 AVG .MAX 和 Sum 等 ) 。 

【 例 4.37】 输出 地 址 中 包含 深圳 .北京 和 上 海 的 公司 信息 。 


Select * From 公司 表 Where 地 址 RLike ' 深 圳 | 北京 I 上海 '; 


其 中 “地 址 RLike' 深 圳 | 北京 1 上 海 '" 就 是 从 公司 表 中 提取 记录 的 条 件 。 
(2) 数据 源 连接 条 件 。 在 From 短语 中 说 明 的 数据 源 之 间 都 应 该 进行 连接 ,通过 连接 
条 件 说 明 各 个 数据 源 中 的 记录 如 何 连接 成 被 操作 的 记录 。 例 如 , 例 4.35 的 “GWB. 岗位 
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编号 = GWCJB. 岗位 编号 ”。 

【 例 4.38】 对 总 分 大 于 或 等 于 80 分 的 应 聘 人 员 ,输出 岗位 编码 .岗位 名 称 、 身 份 证 
号 .姓名 和 总 分 。 

Select GWB. 岗 位 编号 , 岗位 名 称 , YPRYB. 身 份 证 号 ,姓名 ， 

笔试 成 绩 * 笔试 成 绩 比例 /100 + 面试 成 绩 * (1 笔试 成 绩 比例 /100) Rs 总 分 
From GWB, GWCJB, YPRYB 

Where GWB. 岗 位 编号 -GWCJB. 岗 位 编号 And GWCJB. 身 份 证 号 PRYB. 身 份 证 号 
And 笔试 成 绩 * 笔试 成 绩 比例 /100 :面试 成 绩 * (1 -笔试 成 绩 比 例 /100) >=80; 

在 语句 中 ,由 于 GWB 和 GWCJB 中 都 有 “岗位 编号 "字段 ,因此 ,“ 岗 位 编号 "之 前 的 
“GWB. "和 “GWCJB.” 都 不 能 省 略 。 同 样 , “身份 证 号 "之 前 必须 写 *“GWCJB.” 和 
“VPRYB 

在 Where 短语 中 ,表达 式 前 半 部 分 是 3 个 数据 源 的 连接 条 件 , 后 半 部 分 是 提取 记录 的 
条 件 。 虽然 有 关 总 分 的 表达 式 已 经 定义 为 “总 分 "计算 列 ( 非 字 段 ) ,但 在 Where 短语 中 也 
不 能 用 “总 分 > =80" 作 为 提取 记录 的 条 件 。 

运行 语句 的 输出 结果 如 表 4-4 所 示 。 

表 4-4 ”多 数据 源 连接 的 查询 结果 


























岗位 编号 岗位 名 称 身份 证 号 姓名 总 分 
B0001 经 理 助理 11980119921001132X 王 丽 敏 82.5 
B0002 理财 师 11980119921001132X 王 丽 敏 88.5 
B0002 理财 师 219901199001011351 郝 帅 88.7 
A0001 行 长 助理 229901199305011575 赵 明 85.5 
A0002 银行 柜员 229901199503121538 刘 德 厚 81.5 
B0002 理财 师 229901199503121538 刘 德 厚 88.5 








4. 过 滤 查 询 结果 的 数据 行 

在 Select 语句 中 ,可 以 加 相关 短语 对 查询 结果 的 数据 行进 一 步 过 滤 ( 筛 选 ) 。 

(1) Al 1 Distinet[ Row]。 省 略 此 项 或 选用 Al ,表示 输出 查询 结果 的 全 部 数据 行 。 
Distinct[ Row] 表 示 仅 输出 重复 数据 行 中 的 一 行 。 所 谓 重 复数 据 行 是 指 结果 中 对 应 列 的 值 
完全 相同 的 数据 行 。 

【 例 4.39】 输出 已 有 人 申报 的 岗位 编号 和 名 称 ,多 人 申报 的 岗位 仅 输 出 一 次 。 

Select Distinct GWB. 岗 位 编号 , 岗位 名 称 From GWB, GWCJIB 

Where GWB. 岗 位 编号 -GWCJB. 岗 位 编号 ; 

在 语句 中 ,如 果 不 用 Distinet 短语 , 则 每 个 岗位 输出 的 行 数 由 申报 人 数 决定 , 即 某 些 岗 
位 可 能 重复 出 现 多 行 。 

(2) Having < 条 件 表达 式 > 。 对 满足 条 件 的 查询 结果 数据 行进 一 步 过 滤 ( 筛选 )。 
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与 Where < 条 件 表达 式 > 短语 的 主要 区 别 在 于 操作 的 数据 对 象 不 同 。Where 短语 对 数据 
源 中 的 数据 记录 进行 筛选 ;Having 短语 对 查询 结果 数据 行进 一 步 筛 选 ,因此 ,Having 短语 
中 可 以 包含 查询 结果 中 的 列 名 (包括 计算 列 ) 和 统计 函数 。 另 外 ,在 Having 短语 中 不 能 写 
数据 源 之 间 的 连接 条 件 , 它 通常 与 Group By 短语 (数据 分 组 统计 ) 组 合 使 用 。 
【 例 4.40】 用 Having 短语 实现 例 4.38 的 功能 。 
Select GWB. 岗 位 编号 , 岗位 名 称 , YPRYB. 身 份 证 号 ,姓名 ， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 4 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) Rs 总 分 
From GWB, GWCJB, YPRYB 
WhereGWB. 岗 位 编号 =GwcJB. 岗 位 编号 And GRCIB. 身 份 证 号 YPRYB. 身 份 证 号 
Having 总 分 >=80; 
Having 总 分 > =80 中 的 “总 分 "是 计算 列 名 ,但 在 Where 短语 中 不 允许 这 样 用 。 
(3) Limit [ < 开始 行 号 > ,] < 行 数 > 。 用 于 限制 输出 从 开始 行 号 (默认 为 0) 的 指定 
行 数 。 查 询 结果 中 的 数据 行 号 从 0 开始 编号 (查询 结果 中 的 第 一 行 ) 。 省 略 此 短语 ,输出 
全 部 结果 行 ,此 短语 通常 与 Order By( 数 据 记 录 排 序 ) 组 合 使 用 ,输出 前 n 行 。 


4.7.2 数据 排序 分 析 


数据 统计 分 析 主 要 包括 数据 排序 和 分 组 统计 两 方面 的 内 容 。 在 Select 语句 中 加 
“Order By < 排序 关键 字 1 > [ASCIDESC]…[ , < 排序 关键 字 n > [ASCIDESC]]" 短 语 ， 
可 以 对 数据 进行 排序 ,产生 排序 的 查询 结果 。 

排序 关键 字 可 以 是 列 名 (或 字段 ) .查询 结果 中 的 列 号 ( 从 1 开始 排列 号 ) 或 表达 式 ， 
ASC( 或 省 略 ) 表 示 升 序 (由 小 到 大 ) 排 序 ,DESC 表示 降序 ( 由 大 到 小 ) 排 序 。 

【 例 4.41】 输出 年 薪 最 高 的 前 3 个 岗位 的 岗位 编号 .岗位 名 称 和 年 薪 。 

Select 岗位 编号 ,岗位 名 称 , 年 薪 From GWB Order By 年 薪 DESC Limit 3; 

加 Limit < 行 数 > 短语 可 以 输出 一 部 分 排序 记录 ,但 是 ,与 通俗 意义 的 排行 榜 前 多 少 
位 有 些 差 异 ,输出 结果 的 最 后 一 行 后 面 ,可 能 还 有 排序 关键 字 值 相同 的 其 他 数据 行 没 有 输 


出 出 来 。 
当 有 多 个 排序 关键 字 时 , 仅 当 前 面 的 关键 字 值 相 同时 ,数据 记录 才 按 后 面 的 排序 关键 
字 值 排序 。 


【 例 4.42】 输出 岗位 编号 .岗位 名 称 , 申 报 人 员 的 身份 证 号 .姓名 和 总 分 , 按 申报 岗 
位 编号 升序 排列 , 同 岗位 按 总 分 由 高 到 低 排序 。 
Select GWB. 岗 位 编号 , 岗位 名 称 , YPRYB. 身 份 证 号 , 姓名， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比例 /100) Rs 总 分 
From GWB, GWCJB, YPRYB 
Where GWB. 岗 位 编号 =GWCJB. 岗 位 编号 And GWCJB. 身 份 证 号 3YPRYB. 身 份 证 号 
Order By 1, 总 分 DESC; 


其 中 “Order By 1, 总 分 DESC” 表示 对 输出 结果 的 第 一 列 ( 岗位 编号 ) 升序 排列 ,岗位 
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编号 相同 时 再 按 总 分 由 高 到 低 排列 ,输出 结果 如 表 4-5 所 示 。 其 中 ,岗位 编号 相同 的 记录 
连续 输出 ,同一 岗位 的 记录 按 总 分 由 高 到 低 输 出 。 


表 4-5 同 岗位 人 员 总 分 由 高 到 低 排序 






































岗位 编号 岗位 名 称 身份 证 号 姓名 总 分 
A0001 行 长 助理 229901199305011575 赵 明 85.5 
A0001 行 长 助理 11980119921001132X 王 丽 敏 79.5 
A0002 银行 柜员 229901199503121538 刘 德 厚 上 本 
A0002 银行 柜员 229901199305011575 赵 明 人 
A0002 银行 柜员 219901199001011351 郝 帅 70.0 
B0001 经 理 助理 11980119921001132X 王 丽 敏 82.5 
B0001 经 理 助理 219901199001011351 郝 帅 67.5 
B0001 经 理 助理 229901199305011575 赵 明 55.0 
B0002 理财 师 219901199001011351 郝 帅 88.7 
B0002 理财 师 229901199503121538 刘 德 厚 88.5 
B0002 理财 师 11980119921001132X 王 丽 敏 88.5 
B0002 理财 师 229901199305011575 赵 明 75.0 














4.7.3 数据 分 组 统计 分 析 


在 Select 语句 中 加 “Group By < 分 组 关键 字 1 > [ASC1DESC]…[,， < 分 组 关键 
字 n>][ASCIDESC]] [With Rollup]” 短 语 ,可 以 对 数据 进行 分 组 统计 分 析 。 


1. 数据 分 组 


数据 分 组 是 将 分 组 关键 字 值 相同 的 数据 记录 整理 (汇总 ) 成 查询 结果 中 的 一 行 数据 。 
使 用 多 个 分 组 关键 字 可 以 实现 数据 的 多 级 分 组 。 

(1) 分 组 关键 字 : 可 以 是 列 名 (或 字段 ) .查询 结果 中 的 列 号 或 表达 式 , 也 可 以 加 ASC 
(升序 ) 或 DESC( 降 序 ) 短 语 指 定数 据 行 的 排序 方式 ,默认 按 分 组 关键 字 的 值 升序 排列 。 

(2) With Rollup: 用 于 说 明 查 询 结 果 中 增加 分 组 合计 和 总 计 行 。 

【 例 4.43】 输出 已 有 人 申报 的 岗位 编号 和 名 称 ,多 人 申报 的 岗位 仅 输出 一 次 。 

Select GWB. 岗 位 编号 , 岗位 名 称 From GWB，GNCOB 

Where GWB. 岗 位 编号 =-GWCJB. 岗 位 编号 Group By GWB. 岗 位 编号 ; 

语句 中 “岗位 编号 "是 分 组 关键 字 。 执 行 该 语句 时 ,将 岗位 编号 值 相同 的 多 个 记录 
(与 申报 人 员 数 量 有 关 ) 整理 后 成 为 查询 结果 中 的 一 行 数据 。 试 与 例 4.39 比较 ,实现 的 
方法 不 同 , 但 功能 相同 。 
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2. 常用 数据 分 组 统计 分 析 的 函数 


在 进行 数据 统计 分 析 时 ,经 常 在 Select < 表达 式 > 中 使 用 统计 函数 (如 表 4-6 所 示 ) 
与 Group By 短语 结合 完成 相关 的 统计 任务 。 
表 4-6 常用 数据 分 组 统计 分 析 函 数 
函数 名 称 函数 格式 功能 说 明 


计算 数值 表达 式 在 相关 记录 上 的 平均 值 ,车 参数 为 Null, 则 结 
求 平均 值 | AVG( < 数值 表达 式 > ) | 果 为 Null。 如 果 有 分 组 , 则 分 别 计算 每 组 的 平均 值 ;如 果 没 分 
组 , 则 计算 总 平均 值 

统计 数据 行 数 ,参数 可 以 是 任意 表达 式 ,车 参数 为 Null, 则 结果 
计数 Count( < 参数 >1*) 为 0。 如 果 有 分 组 , 则 分 别 统计 每 组 中 的 数据 行 数 ;如 果 没 分 
组 , 则 统计 数据 总 行 数 


计算 数值 表达 式 在 相关 记录 上 的 最 大 值 , 若 参 数 为 Null, 则 结 
求 最 大 值 | Max( < 数值 表达 式 > ) | 果 为 Null。 如 果 有 分 组 , 则 分 别 计算 各 组 中 的 最 大 值 ;如 果 没 
分 组 , 则 计算 全 部 数据 行 中 的 最 大 值 

计算 数值 表达 式 在 相关 记录 上 的 最 小 值 , 若 参 数 为 Null, 则 结 
求 最 小 值 | Min( < 数值 表达 式 > ) ”| 果 为 Null。 如 果 有 分 组 , 则 分 别 计算 各 组 中 的 最 小 值 ;如 果 没 
分 组 , 则 计算 全 部 数据 行 中 的 最 小 值 

计算 数值 表达 式 在 相关 记录 上 的 合计 , 若 参 数 为 Null, 则 结果 
求 合计 “| Sum( < 数值 表达 式 > ) | 为 Null。 如 果 有 分 组 , 则 分 别 计 算 各 组 的 小 计 ; 如 果 没 分 组 , 则 
计算 全 部 数据 行 的 合计 























【 例 4.44】 输出 每 个 岗位 的 岗位 编号 、 名 称 , 人 数 (招聘 ) .申报 人 数 以 及 总 分 的 最 
高 分 .最 低 分 及 平均 分 。 


Select GWB. 岗 位 编号 , 岗位 名 称 , 人 数 As 招聘 人 数 , Count (* ) Rs 申报 人 数 ， 
Max (笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100)) as 最 高 分 ， 
Min (笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100)) as 最 低 分 ， 
Avg (笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) ) as 平均 分 

From GWB，GWCOB 

Where GWB. 岗 位 编号 =<GWCOB .岗位 编号 Group By GWB. 岗 位 编号 ; 


语句 中 “岗位 编号 "是 分 组 关键 字 , 使 用 Count、Max、Min 和 Avg 函数 统计 出 每 个 岗位 
的 申报 情况 ,输出 结果 如 表 4-7 所 示 。 


表 4-7 ”岗位 分 组 统计 分 析 














岗位 编号 岗位 名 称 招聘 人 数 申报 人 数 最 高 分 最 低 分 平均 分 
AOOO1 行 长 助理 | - 85.5 79.5 82.5 
A0002 银行 柜员 3 a 81.5 70.0 5:7 
B0001 经 理 助理 3 3 82.5 55.0 
B0002 理财 师 12 4 88.7 75.0 85.2 




















基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


Group By 经 常 与 Having < 条 件 表达 式 > 短语 组 合 使 用 ,对 查询 统计 的 结果 做 进一步 
筛选 。 例 如 ,在 本 例 的 语句 最 后 再 加 “Having 招聘 人 数 > 申报 人 数 ” ,将 输出 还 没有 满 额 
的 岗位 情况 , 即 表 4-7 中 不 再 显示 A0001 和 B0001 两 个 岗位 的 数据 。 

3. 分 组 结果 数据 的 解释 

在 表 4-7 的 分 组 统计 结果 中 ,统计 列 ( 如 申报 人 数 .最 高 分 .最 低 分 和 平均 分 ) 是 分 组 
关键 字 ( 如 岗位 编号 ) 或 分 组 关键 字 能 唯一 确定 列 ( 岗位 名 称 和 招聘 人 数 ) 的 对 应 统计 结 
果 。 如 果 在 例 4.44 中 再 加 身份 证 号 列 , 则 输出 结果 为 表 4-8。 

表 4-8 含 其 他 列 的 岗位 分 组 统计 分 析 














岗位 编号 | 岗位 名 称 身份 证 号 招聘 人 数 | 申报 人 数 | 最 高 分 | 最 低 分 | 平均 分 
A0001 | 行 长 助理 | 11980119921001132X 1 2 85.5 79.5 82.5 
A0002 “| 银行 柜员 | 219901199001011351 5 3 81.5 70.0 5 
B0001 “| 经 理 助理 | 11980119921001132X 3 3 RS 55.0 68.3 
B0002 “| 理财 师 11980119921001132X 12 4 88.7 75.0 85.2 























表 中 身份 证 号 列 不 是 统计 和 分 组 关键 字 列 ,也 不 是 分 组 关键 字 能 唯一 确定 的 列 , 即 身 
份 证 号 与 各 个 统计 列 没有 依存 关系 。 应 该 解释 为 : 身份 证 号 为 11980119921001132X 的 
人 员 申 报 了 行 长 助理 经理 助 理 等 岗位 , 仅 此 而 已 ,并 不 一 定 是 所 报 岗 位 的 最 高 分 .最 低 分 
或 平均 分 的 得 主 。 

由 此 可 知 ,在 分 组 统计 结果 中 ,统计 列 ,分 组 关键 字 列 和 分 组 关键 字 能 唯一 确定 的 列 
以 外 的 其 他 列 数据 ,只 是 对 应 组 内 该 列 的 一 个 数据 ,与 统计 结果 没有 依存 关系 。 


4.7.4 多 个 数据 源 连接 


Select 语句 可 以 连接 多 个 数据 源 ,形成 一 个 数据 查询 结果 。 多 个 数据 源 进 行 连接 , 实 
质 是 利用 连接 条 件 两 两 连接 实现 的 。 通 过 Where 短语 设置 连接 条 件 , 可 以 实现 多 个 数据 
源 的 连接 ,但 连接 功能 和 效率 (时 间 ) 等 方面 都 受到 限制 。 例 如 ,要 查看 目前 还 没有 人 申 
报 的 岗位 情况 ,直接 通过 Where 短语 设置 连接 条 件 是 难以 实现 的 。Select 语句 提供 了 下 
列 专用 的 数据 源 连接 和 设置 连接 条 件 的 短语 。 

语句 格式 : 

Select … From < 数据 源 名 1 >[ < 连接 类 型 >< 数 据 源 名 2 >… 

< 连接 类 型 > 数据 源 名 n 习 
[on < 条 件 表达 式 习 … 

从 语句 格式 上 ,将 From 短语 中 的 各 个 数据 源 之 间 的 逗号 换 成 连接 类 型 ,从 Where 短 
语 中 提取 出 各 个 数据 源 之 间 的 连接 条 件 放 在 On 之 后 ,其 他 功能 的 短语 格式 不 变 。 某 些 
连接 类 型 甚至 不 需要 On < 条 件 表 达 式 > 。 
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1. On < 条 件 表达 式 > 


On < 条 件 表达 式 > 用 于 设置 数据 源 之 间 的 连接 条 件 。 所 谓 数据 源 连 接 就 是 在 两 个 
数据 源 内 找 能 满足 连接 条 件 的 记录 ,每 当 找到 一 对 满足 条 件 的 记录 ,就 将 它们 连接 成 一 条 
被 操作 的 记录 。 

On < 条 件 表达 式 > 短语 只 适合 From 短语 中 各 个 数据 源 之 间 用 “连接 类 型 ” ,如 果 数 
据 源 之 间 用 逗号 分 隔 , 则 不 能 用 该 短语 设置 连接 条 件 。 


2. 数据 源 连接 类 型 


(1) [ Inner ]Join, 内 连接 。 仅 连接 两 个 数据 源 中 符合 连接 条 件 的 数据 记录 。 
【 例 4.45】 用 内 连接 方式 ,输出 岗位 编号 .岗位 名 称 ,申报 人 员 的 身份 证 号 .姓名 和 
总 分 ,申报 同 岗位 人 员 按 总 分 由 高 到 低 排 序 。 
Select GWB. 岗 位 编号 , 岗位 名 称 , YPRYB. 身 份 证 号 , 姓名 ， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比例 /100) Rs 总 分 
From GWB Inner Join GWCJB Join YPRYB 
on GWB. 岗 位 编号 <GWCOB. 岗 位 编号 And GWCJB. 身 份 证 号 SYPRYB. 身 份 证 号 
Order By 1, 总 分 DESC; 
本 语句 与 例 4.42 比较 ,功能 完全 相同 。 当 数据 量 比较 大 时 ,本 语句 的 运行 速度 更 快 
一 些 。 
(2) Natural Join ,自然 连接 。 是 以 两 个 数据 源 中 同名 字段 值 相 等 为 连接 条 件 的 内 连 
接 。 与 内 连接 比较 ,二 者 主要 差异 如 下 : 
。 在 内 连接 中 ,同名 字段 相等 的 条 件 必 须 用 On < 条件 表达 式 > 说 明 , 而 自然 连接 中 
不 需要 说 明 连 接 条 件 。 
。 用 “x* ”输出 两 个 数据 源 中 的 全 部 字段 时 ,对 两 个 数据 源 中 的 同名 字段 ,内 连接 输 
出 两 列 , 而 自然 连接 输出 一 列 。 
。 两 个 或 更 多 数据 源 中 出 现 的 同名 字段 ,可 以 省 略 字段 名 前 面 的 数据 源 名 和 圆 点 。 
【 例 4.46】 用 自然 连接 方式 ,实现 例 4.45 的 功能 。 
Select 岗位 编号 , 岗位 名 称 ， 身份 证 号 , 姓名， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) Rs 总 分 
From GWB Natural Join GWCJB Natural Join YPRYB 
Order By 1, 总 分 DESC; 
此 语句 中 没有 On < 条件 表达 式 > 短语 ,实际 隐 含 说 明 连 接 条 件 为 “GWB. 岗位 编 
号 = GWCJB. 岗位 编号 And GWCJB. 身份 证 号 = YPRYB. 身份 证 号 ” ,并 且 岗 位 编号 字段 
前 省 略 了 “GWB.”, 身份 证 号 字段 前 省 略 了 “YPRYB.”。 
【 例 4.47】 用 内 连接 和 自然 连接 两 种 方式 输出 GWB 和 GWCJB 中 的 全 部 字段 , 试 比 
较 语句 及 查询 结果 的 差异 。 


Select * From GWB Natural Join GWCJB; /* 自然 连接 * / 
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Select * From GWB Join GWCJB On GWB. 岗 位 编号 =GWCJIB. 岗 位 编号 ; /* 内 连接 * / 


前 一 条 语句 ( 自然 连接 ) 输 出 的 结果 中 包含 一 列 岗位 编号 ,而 后 一 条 语句 ( 内 连接 ) 输 
出 的 结果 中 包含 两 列 岗位 编号 , 除 此 以 外 ,结果 完全 相同 。 
(3) Left [ Outer] Join, 左 连接 。 连 接 两 个 数据 源 中 符合 连接 条 件 的 记录 ,再 加 上 左 
数据 源 中 不 符合 连接 条 件 的 记录 。 
【 例 4.48】 输出 GWB 中 全 部 记录 的 岗位 编号 和 岗位 名 称 , 对 于 有 人 申报 的 岗位 , 输 
出 其 中 一 个 申报 人 的 身份 证 号 。 
Select GWB. 岗 位 编号 , 岗位 名 称 ,身份 证 号 
From GWB Left Join GWCJB On GWB. 岗 位 编号 =GWCJB. 岗 位 编号 
Group By GWB. 岗 位 编号 ; 
运行 语句 的 输出 结果 如 表 4-9 所 示 。 
表 4-9 左 连 接 的 岗位 情况 























岗位 编号 岗位 名 称 身份 证 号 
A0001 行 长 助理 11980119921001132X 
A0002 银行 柜员 219901199001011351 
A0003 律师 Null 
A0004 会 计 Null 
B0001 经 理 助理 11980119921001132X 
B0002 理财 师 11980119921001132X 
B0003 岗 前 培训 师 Null 








从 输出 的 结果 ( 表 4-9 ) 可 以 看 出 ,如 果 左 数据 源 GWB 中 的 记录 (如 A0003 、A0004 和 
B0003 ) 在 右 数 据 源 GWCJB 中 找 不 到 符合 连接 条 件 (岗位 编号 相等 ) 的 记录 , 则 查询 结果 
中 关于 右 数据 源 的 字段 (如 身份 证 号 ) 值 为 Null。 充 分 利用 这 个 特点 ,可 以 使 应 用 更 为 
3 

【 例 4.49】 分 别 输 出 有 人 申报 和 无 人 申报 的 岗位 。 

Select GWB. 岗 位 编号 , 岗位 名 称 ,身份 证 号 

From GWB Left Join GWCJB On GWB. 岗 位 编号 =GWCJB. 岗 位 编号 

Group By GWB. 岗 位 编号 Having Not IsNull (身份 证 号 ); /* 有 人 申报 的 记录 * / 
Select GWB. 岗 位 编号 , 岗位 名 称 ,身份 证 号 

From GWB Left Join GWCJB On GWB. 岗 位 编号 =GWCJB. 岗 位 编号 

Group By GWB. 岗 位 编号 Having IsNull (身份 证 号 ); /*# 无 人 申报 的 记录 * / 

第 一 条 语句 输出 表 4-9 中 有 人 申报 的 岗位 编码 A0001 、A0002 .B0001 和 B0002 四 行 ， 
而 第 二 条 语句 输出 表 4-9 中 无 人 申报 的 岗位 编码 A0003 .A0004 和 B0003 三 行 。 

(4) Right [ Outer] Join , 右 连 接 。 连 接 两 个 数据 源 中 符合 连接 条 件 的 记录 ,再 追加 上 
右 数据 源 中 不 符合 连接 条 件 的 记录 。 实 质 上 ,将 左右 数据 源 互 换 位置 , 左 连接 与 右 连接 没 
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有 本 质 的 区 别 。 





4.8 SQL 语句 的 嵌 套 


在 实际 应 用 中 ,有 些 比较 复杂 的 问题 ,如 统计 各 个 岗位 最 高 分 得 主 、 高 于 平均 成 绩 的 
人 员 情 况 ,没有 人 申报 的 岗位 ,依据 其 他 数据 源 中 的 数据 更 新 一 个 表 等 ,用 一 条 基本 SQL 
语句 很 难 完成 任务 ,往往 需要 多 条 SQL 语句 合作 ,或 者 ,用 一 条 SQL 语句 再 结合 若干 条 子 
查询 语句 (Select) 才能 完成 任务 , 即 ,利用 SQL 语句 的 嵌 套 形式 可 以 解决 更 复杂 的 实际 应 
用 问题 。 


4.8.1 主 SQL 语句 与 子 查询 


通常 将 嵌 套 在 SQL 语句 中 的 Select 语句 称 为 子 查询 或 子 语句 ,将 写 在 外 层 的 SQL 语 
句 称 为 主 SQL 语句 。 在 一 个 主 SQL 语句 中 ,可 以 嵌 套 多 个 子 查询 语句 , 子 查询 语句 中 还 
可 以 再 次 嵌 套 子 查询 。 

当 没 有 满足 条 件 的 数据 记录 时 ,如 果 独 立 运行 一 条 查询 语句 ( Select) , 则 查询 结果 为 
空 (0 个 记录 ) ;如 果 作为 子 查 询 语句 运行 , 则 查询 结果 对 应 值 为 Null。 

执行 嵌 套 的 SQL 语句 时 ,要 求 用 户 除 具有 Select 访问 权限 外 ,还 要 有 与 主语 句 对 应 的 
访问 权限 。 


1. 子 查询 语句 的 嵌 套 格式 


在 MySQL 中 , 主 SQL 语句 可 以 是 Update .Delete 或 Select, 将 子 查 询 语句 用 小 括号 括 
起 来 ,作为 一 个 数据 项 能 套 在 主 SQL 语句 的 表达 式 中 ,小 括号 不 仅 表 示 子 查询 优先 运算 ， 
也 表示 子 查询 语句 是 一 个 完整 的 运算 项 ,可 以 进一步 参与 表达 式 中 的 其 他 运算 。 

【 例 4.50】 输出 目前 无 人 申报 的 岗位 编号 ,名称 和 招聘 人 数 。 

Select 岗位 编号 , 岗位 名 称 , 人 数 From GWB Where 岗位 编号 Not In 

(Select Distinct 岗位 编号 From GWCJB) ; 

其 中 “Select Distinct 岗位 编号 From GWCJB”" 是 租 套 在 Where < 条 件 表达 式 > 中 的 子 
查询 语句 ,其 左右 小 括号 不 能 省 略 ;外 层 的 Select 语句 是 主 SQL 语句 。 由 子 查询 语句 从 
GWCJB 中 提取 出 全 部 岗位 编号 (有 人 申报 的 岗位 编号 集合 ) ,为 主语 句 判断 GWB 中 的 每 
个 记录 是 否 符合 条 件 提供 了 数据 依据 。 当 GWCJB 为 空 时 , 子 查 询 的 结果 为 Null。 


2. 子 查询 语句 的 炭 套 位 置 


在 MySQL 中 ,通常 在 下 列表 达 式 中 可 以 说 套 子 查 询 语句 : 
(1) Select < 表达 式 > 。 在 Select < 表达 式 > 中 肉 套 子 查询 语句 ,作为 主 查 询 语句 输 
出 某 列 的 表达 式 或 数据 项 ,从 其 他 数据 源 中 提取 主语 句 所 需要 的 数据 。 如 果子 查询 语句 
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结果 不 参与 其 他 运算 ,自身 就 构成 了 表达 式 , 则 子 查询 结果 必须 是 一 个 数据 或 Null( 表示 
没有 符合 子 查询 条 件 的 数据 ) , 即 子 查询 结果 不 能 是 多 行 ( 二 2) 或 多 列 数据 。 

【 例 4.51】 输出 申报 人 员 的 身份 证 号 .姓名 .岗位 名 称 .笔试 成 绩 和 面试 成 绩 。 

Select 身份 证 号 ， 

(Select 姓名 From YPRYB Where YPRYB. 身 份 证 号 =-GWCJB. 身 份 证 号 ) Rs 姓名 ， 

(Select 岗位 名 称 From GWB Where GWB. 岗 位 编号 -GWCJB. 岗 位 编号 ) as 岗位 名 称 ， 

笔试 成 绩 ,面试 成 绩 From GWCJB; 

主语 句 中 符 套 两 个 子 查询 语句 ,前 一 条 子 查询 语句 从 YPRYB 中 为 主语 句 提取 姓名 
数据 ,后 一 条 子 查询 语句 从 GWB 中 为 主语 句 提取 岗位 名 称 数 据 。 

(2) Update < 表 名 > Set < 字段 名 > = < 表达 式 > 。 在 Set < 字段 名 > = < 表达 
式 > 中 髋 套子 查询 语句 ,利用 其 他 数据 源 中 的 数据 修改 主语 句 中 表 的 字段 值 。 

这 种 藤 套 语句 要 求 : 子 查询 语句 中 的 数据 源 不 能 是 主语 句 要 修改 的 表 ; 如果 表达 式 
就 是 由 子 查询 语句 单独 构成 的 , 则 子 查询 结果 必须 为 一 个 数据 或 Null。 

【 例 4.52】 假设 资格 审核 的 条 件 是 : 满足 学 历 和 学 位 要 求 ,并 且 笔 试 和 面试 成 绩 均 
60 分 及 以 上 ,用 一 条 SQL 语句 填写 “资格 审核 "字段 的 值 。 

Update GWCJB Set 资格 审核 = 

(Select 最 后 学 历 >= 最 低 学 历 and 最 后 学 位 >= 最 低 学 位 From GWB，YPRYB Where 
YPRYB. 身 份 证 号 =GWCJB. 身 份 证 号 And GWB. 岗 位 编号 <SWCOB. 岗 位 编号 ) 
And 笔试 成 绩 >=60 And 面试 成 绩 >=60; 

子 查 询 语句 作为 表达 式 的 一 部 分 ,结果 是 一 个 逻辑 型 数据 , 它 直 接 与 主语 句 中 的 其 他 
运算 项 进行 逻辑 ( And) 运算 ,将 运算 结果 填 人 “资格 审核 "字段 。 

(3) Where < 条 件 表 达 式 > 。 在 Update .Delete 和 Select 为 主语 句 的 Where < 条 件 表 
达 式 > 中 可 以 骨 套 子 查询 语句 ,用 其 他 数据 源 为 主语 句 提供 判断 数据 记录 的 依据 。 但 是 ， 
子 查询 语句 中 的 数据 源 不 能 是 主语 句 Update 或 Delete 要 更 新 或 删除 数据 记录 的 表 。 

【 例 4.53】 删除 YPRYB 中 没有 申报 岗位 的 记录 。 


Delete From YPRYB Where 身份 证 号 Not In 
(Select 身份 证 号 From GWCJB Where GWCJB. 身 份 证 号 YPRYB. 身 份 证 号 ); 


子 查询 为 主语 句 提供 申报 岗位 人 员 身 份 证 号 的 集合 (一 列 多 行 身份 证 号 ) ,因此 , 主 
语句 中 需要 用 集合 运算 符号 ( Not In) 与 之 运算 。 
【 例 4.54】 输出 已 经 通过 资格 审核 且 笔 试 成 绩 高 于 所 报 岗 位 平均 分 的 身份 证 号 、 姓 
名 岗位 名 称 \ 学 历 ,笔试 成 绩 和 面试 成 绩 , 按 申报 岗位 名 称 升序 排列 , 同 岗 位 按 面试 成 绩 
由 高 到 低 排 序 。 
Select 身份 证 号 , 姓名 ,岗位 名 称 ， 
HT (最 后 学 历 , ' 无 学 历 ',' 专 科 ', "本科 ', "研究 生 ', ' 博 士 ') as 学 历 ， 
笔试 成 绩 , 面试 成 绩 
From YPRYB Natural Join GWCJB Natural Join WB 


Where 资格 审核 and 笔试 成 绩 > 
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(Select AVG (笔试 成 绩 ) From GWCJB Rs CJB Where GWB. 岗 位 编号 -CJB. 岗 位 编号 ) 
Order By 岗位 名 称 ,面试 成 绩 DESC; 
主语 句 通过 自然 连接 ( NaturalJoin ,不 需要 写 连接 条 件 ) 将 3 个 表 连 接 起 来 。 子 查询 
的 结果 为 当前 岗位 笔试 成 绩 的 平均 值 (一 个 数据 ) ,所 以 ,主语 句 中 可 以 用 > ”与 之 运算 。 
主语 句 和 子 查询 语句 中 的 数据 源 都 用 了 GWCJB ,为 了 便于 引用 ,要 对 数据 源 之 一 另 
起 别名 (如 As CJB) 。 另 外 ,ELT( ) 为 数码 转换 名 称 函 数 , 将 最 后 学 历 码 转换 成 学 历 名 。 


4.8.2 和 嵌 套 语句 的 执行 过 程 


主 SQL 语句 与 子 查询 语句 的 执行 过 程 如 图 44 的 流程 图 所 示 。 


开始 执行 主语 句 








(主语 句 结束 ) | 。。 置 成 当前 记录 





引用 主语 句 当前 记录 的 
数据 ， 执 行 子 查询 








利用 子 查询 结果 的 数据 ， 
继续 计算 主语 句 中 的 表 
达 式 ， 处 理 主语 句 的 当前 
记录 














图 44 嵌 套 语句 的 执行 过 程 


在 执行 主 SQL 语句 时 ,每 处 理 一 个 数据 记录 ,都 要 执行 一 次 子 查询 语句 (可 能 引用 主 
语句 的 当前 记录 的 数据 ) ,然后 将 子 查 询 的 结果 再 作用 于 主 SQL 语句 的 当前 记录 上 。 

例 4.50 中 ,根据 SQL 和 骨 套 语句 的 执行 过 程 ,虽然 每 次 执行 子 查 询 语 句 的 结果 都 相同 
(有 人 申报 的 全 部 岗位 编号 ) ,但 是 ,对 GWB 中 的 每 个 数据 记录 还 要 重复 执行 “Select 
Distinct 岗位 编号 From GWCJB" 语 句 , 即 ,执行 子 查 询 语句 的 次 数 与 GWB 中 的 数据 记录 
个 数 一 致 。 因 此 ,在 设计 子 查询 时 ,应 该 进行 适当 优化 ,努力 平衡 语句 的 复杂 程度 与 子 查 
询 结果 中 数据 量 之 间 的 关系 ,尽量 提高 执行 SQL 嵌 套 语句 的 时 间 和 空间 效率 。 

【 例 4.55】 对 例 4.50 中 的 子 查 询 语句 进行 优化 ,功能 不 变 , 以 便 减少 每 次 执行 子 查 
询 时 结果 的 数据 量 。 

Select 岗位 编号 , 岗位 名 称 , 人 数 From GWB Where 岗位 编号 Not In 

(Select Distinct 岗位 编号 From GWCJB Where GWCJB. 岗 位 编号 =-GWB. 岗 位 编号 ) ; 
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在 执行 此 艇 套 语句 过 程 中 ,每 当主 语句 从 GWB 中 提取 出 一 条 记录 ,都 依据 该 记录 的 
岗位 编号 (如 A0003 或 B0001 等 ) 执行 子 查询 语句 (如 Select Distinct 岗位 编号 From 
GWCJB Where GWCJB. 岗位 编号 =' A0003 ' 或 Select 岗位 编号 From GWCJB Where 
GWCJB. 岗位 编号 =' B0001' 等 ) ,每 次 只 从 GWCJB 中 提取 与 主语 句 当前 记录 的 岗位 编号 相 
等 的 数据 ,与 GWCJB 中 全 部 记录 的 岗位 编号 相 比 , 减 少 了 大 量 数据 ,从 而 提高 了 运行 效率 。 


4.8.3 子 查询 的 运算 规则 


子 查询 语句 的 运行 结果 可 能 是 一 个 (一 个 单元 格 ) 或 多 个 数据 ( 多 行 或 多 列 ,通常 是 
一 列 多 行 , 也 称 数据 集 ) ,甚至 可 能 是 Null( 无 查询 结果 ) 。 

对 于 查询 结果 为 一 个 数据 ( 含 Null) 的 子 查询 ,可 以 将 其 视 为 一 个 普通 数据 ,进行 算 
术 运 算 ( +、- 、* 和 /等 ) 或 比较 运算 ( <、> 和 = 等 ) ,如 例 4.54。 也 可 以 进行 逻辑 运算 
(Not And 和 Or 等) ,如 例 4.52 ,甚至 可 以 作为 调用 函数 (如 Sqrt 和 IsNull 等 ) 的 参数 。 

当 子 查询 结果 为 数据 集 时 ,必须 用 集合 谓词 运算 符 ([ Not] mm) 对 其 进行 运算 ( 如 
例 4.50 和 例 4.53)。 当 然 , 集 合 谓词 运算 符 也 可 以 对 结果 为 一 个 数据 或 Nul 的 子 查 询 结 
果 进 行 运算 (如 例 4.55)。 除 了 集合 运算 符 以 外 ,MySQL 还 提供 了 一 些 专 门 用 于 子 查 询 结 
果 的 谓词 运算 。 

1. All 运算 符 

运算 格式 : 

< 表达 式 >< 比 较 运算 符 妆 11 (< 子 查询 语句 >) 

Al 运算 要 求 子 查询 的 结果 是 一 列 数据 集 ( 含 Null) 。 如 果 表 达 式 的 值 与 子 查询 结果 
中 的 每 个 值 比较 运算 都 成 立 , 则 运算 结果 为 1( 真 ) ,否则 ,运算 结果 为 0( 假 ) 。 

【 例 4.56】 输出 所 报 岗位 (至 少 申 报 一 个 ) 笔试 成 绩 均 在 70 分 以 上 人 员 的 身份 证 号 
和 姓名 。 

Select 身份 证 号 , 姓名 From YPRYB Where 

身份 证 号 In (Select 身份 证 号 From GWCJB Where GWCJB. 身份 证 号 YPRYB. 身 份 证 号 ) 
and 
70 <All (Select 笔试 成 绩 From GWCJB Where GWCJB. 身 份 证 号 AYPRYB. 身 份 证 号 ); 

主语 句 中 髋 套 了 两 个 子 查 询 语句 ,前 一 个 子 查 询 语 句 从 GWCJB 中 提取 其 身份 证 号 
数据 集 ,以 确保 至 少 申报 一 个 岗位 ;后 一 个 子 查 询 语句 从 GWCJB 中 提取 主语 句 中 当前 申 
报 人 员 的 笔试 成 绩 数据 集 ,为 *< AI" 运算 提供 数据 。 

语句 中 后 一 个 子 查询 语句 及 其 运算 不 能 用 “70 < 笔试 成 绩 " 取 而 代 之 ,因为 它 将 筛 除 
笔试 成 绩 小 于 或 等 于 70 分 的 所 有 记录 。 

【 例 4.57】 输出 每 个 岗位 编号 .最 高 面试 成 绩 和 获得 此 成 绩 的 身份 证 号 。 

Select 岗位 编号 , 面试 成 绩 As 最 高 面试 成 绩 ,身份 证 号 From GWCJB 

Where 面试 成 绩 >=A11 
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(Select 面试 成 绩 From GWCJB As CJB Where CJB. 岗 位 编号 -GWCJB. 岗 位 编号 ) ; 


子 查询 语句 从 GWCJB 中 提取 出 主语 句 中 当前 岗位 全 部 人 员 的 面试 成 绩 数据 集 , 然 
后 主语 句 用 “面试 成 绩 > = Al "与 该 数据 集 进 行 运算 。 由 于 子 查询 的 结果 中 可 能 有 多 个 
数据 (数据 集 ) ,因此 ,不 能 省 略 Al。 如 果 确 保 子 查询 的 结果 为 一 个 数据 或 Null , 则 可 以 省 
略 All。 与 之 等 效 的 另 一 条 语句 如 下 : 
Select 岗位 编号 , 面试 成 绩 Rs 最 高 面试 成 绩 ,身份 证 号 From GRCOB 
Where 面试 成 绩 = 
(Select Max (面试 成 绩 ) From GWCJB Rs CJB Where CJB. 岗 位 编号 =GWCJB. 岗 位 编号 ) ; 
在 改造 后 的 语句 中 ,运算 符 ” =" 换 成 * > =”* = All" 或 “In" 都 不 会 改变 语句 的 总 体 
功能 。 但 是 ,不 能 用 下 列 语句 实现 例 4. 57 的 要 求 : 
Select 岗位 编号 ,Max (面试 成 绩 ) Rs 最 高 面试 成 绩 ,身份 证 号 From GWCOB 
Group By 岗位 编号 ; 
此 语句 中 的 岗位 编号 与 最 高 面试 成 绩 的 对 应 关系 没有 问题 ,但 获得 此 成 绩 的 人 员 未 
必 是 对 应 的 身份 证 号 。 问 题 主要 在 于 : 身份 证 号 列 既 不 是 分 组 关键 和 统计 列 , 也 不 是 分 
组 关键 字 岗 位 编号 能 唯一 确定 的 列 ,因此 ,语句 中 的 身份 证 号 与 岗位 编号 只 是 申报 关系 ， 
与 最 高 面试 成 绩 没 有 对 应 关系 。 
2. Any1Some 运算 
运算 格式 : 
< 表达 式 >< 比 较 运 算 符 Any lSome ( < 于 查询 语句 >) 
Any 与 Some 功能 相同 ,要 求 子 查询 的 结果 是 一 列 数据 集 ( 含 Null) 。 如 果 表 达 式 的 值 
与 子 查询 结果 中 的 某 个 (或 某 些 ) 值 比较 运算 成 立 , 则 运算 结果 为 1( 真 ) ;如 果 表 达 式 的 
值 与 子 查 询 结果 中 的 任何 值 比 较 运算 都 不 成 立 , 则 运算 结果 为 0( 假 ) 。 
【 例 4.58】 输出 目前 还 存在 没 面试 ( 面试 成 绩 为 0) 人 员 的 岗位 编号 和 岗位 名 称 。 
Select 岗位 编号 , 岗位 名 称 From GWB Where 0 ny 
(Select 面试 成 绩 From GWCJB Where GWCJB. 岗 位 编号 =-GWB. 岗 位 编号 ) ; 
子 查询 语句 从 CWCJB 中 提取 出 主语 句 中 当前 岗位 全 部 申报 人 员 的 面试 成 绩 数据 
集 , 若 其 中 有 一 个 申报 人 员 的 面试 成 绩 为 0, 则 与 之 运算 的 0=Any 就 成 立 。 
由 于 一 个 岗位 中 可 能 有 多 个 申报 人 员 的 面试 成 绩 为 0, 因 此 不 能 用 下 列 语句 实现 
例 4.58 , 它 可 能 使 一 个 岗位 输出 多 行 。 事 实 上 ,在 下 列 语句 基础 上 再 加 Distinet 短语 才能 
实现 例 4.58。 
Select GWB. 岗 位 编号 , 岗位 名 称 From GWB，GWCJB Where 面试 成 绩 -0 And 
GRCOB .岗位 编号 =GWB. 岗 位 编号 ; 


3. Exists 运算 
运算 格式 
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[Not] Exists (< 于 查询 语句 为 
Exists 是 单 目 运算 符 , 对 子 查询 结果 的 列 数 和 行 数 均 无 特殊 要 求 。 如 果子 查询 结果 
中 有 数据 ( 非 Null) , 则 Exists 运算 结果 为 1( 真 ) ,否则 ,运算 结果 为 0( 假 ) 。 
【 例 4.59】 输出 目前 无 人 申报 的 岗位 编号 .名 称 和 招聘 人 数 。 
Select 岗位 编号 , 岗位 名 称 , 人 数 From GWB Where Not Exists 
(Select * From GWCJB Where GWCJB. 岗 位 编号 =GWB. 岗 位 编号 ); 
本 语句 与 例 4.50 和 例 4.55 比较 ,功能 完全 相同 ,只 是 实现 方法 不 同 。 
【 例 4.60】 按 姓名 排序 ,输出 重 名 人 员 的 身份 证 号 和 姓名 。 
Select 身份 证 号 ,姓名 From YPRYB Where Exists 
(Select * From YPRYB Rs RYB 
Where RYB. 姓 名 =YPRYB. 姓 名 And RYB. 身 份 证 号 <>YPRYB. 身 份 证 号 ) 
Order By 姓名 ; 
主语 名 和子 查询 语句 中 的 数据 都 来 源 于 YPRYB ,为 了 便于 引用 表 , 必须 对 其 中 之 一 
另 起 别 名 (如 As RYB) 。 子 查询 语句 从 YPRYB 中 提取 出 与 主语 句 中 当前 人 员 姓 名 相同 
而 身份 证 号 不 同 的 记录 ,如 果子 查询 结果 中 有 这 样 的 记录 , 则 说 明 主 语句 中 的 当前 人 员 至 
少 有 (Exists) 一 个 其 他 记录 与 其 姓名 相同 。 


4.9 SQL 语句 合并 


在 MySQL 中 ,将 一 条 Create Table ,Insert 、Replace 或 Select 语句 (也 称 子 语句 ,简称 子 
句 ) 与 另 一 条 查询 语句 (Select) 合 并 成 一 条 语句 , 称 为 SQL 语句 的 合并 。 被 合并 的 Select 
语句 也 被 称 为 Select 子 句 ,同时 也 是 一 条 能 够 独立 运行 的 简单 查询 .数据 统计 分 析 以 及 衣 
套 的 查询 语句 。 


4.9.1 创建 表 与 查询 语句 合并 


Create Table 子 句 可 以 与 Select 子 句 合并 成 一 条 语句 ,以 便 依据 Select 子 句 的 查询 结 
果 ( 表 结构 及 其 数据 记录 ) 创 建新 表 , 通 常 适用 于 表 备 份 和 数据 记录 分 类 存储 等 。 执 行 创 
建 表 与 查询 合并 语句 ,要求 用 户 同 时 具有 Select Create 和 Insert 三 种 权限 。 

语句 格式 : 

<Create Table 子 句 描述 >[As] <Select 子 句 描述 > 


实质 上 本 语句 是 Create Table 和 Select 两 条 语句 通过 As 的 合成 体 ,省 略 As 时 ,两 个 
子 语句 之 间 至 少 有 一 个 空格 。 

执行 这 条 语句 时 ,新 表 中 的 字段 是 Create Table 子 句 定 义 的 字段 和 Select 子 句 查询 结 
果 中 列 的 并 集 , 表 及 其 字段 的 属性 (如 表 名 主键、 外 键 、 字 段 的 数据 类 型 .宽度 和 默认 值 
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等 ) 由 Create Table 子 句 定义 ;Create Table 子 句 中 没有 定义 的 字段 , 取 Select 子 句 查 询 结 
果 列 的 数据 类 型 .宽度 和 默认 值 。 

新 表 是 否 有 主键 和 外 键 取 决 于 Create Table 子 句 中 的 定义 ,与 Select 子 句 的 数据 源 中 
的 主键 和 外 键 没 有 关系 。 新 表 中 的 数据 由 Select 子 句 查询 结果 的 数据 记录 决定 ,Select 子 
名 查询 结果 中 没有 , 而 在 Create Table 子 句 中 定义 的 字段 ,各 个 记录 中 该 字段 都 填 
Null 值 。 

【 例 4.61】 将 GWB 完整 地 备份 到 GWBBF 中 ,岗位 编号 仍然 为 主键 。 


Create Table GWBBF (Primary Key (岗位 编号 ) ) Rs Select * From GWB; 


在 Create Table 子 句 中 ,虽然 没有 描述 有 关 字 段 的 属性 ,但 新 表 GWBBF 中 仍然 保留 
着 GWB 中 的 相关 属性 ,包括 字段 名 称 .数据 类 型 .主键 和 数据 记录 等 。 

【 例 4.62】 创建 新 表 ZGSH ,保留 GWCJB 中 资格 审核 以 外 的 字段 ,存储 GWCJB 中 
通过 资格 审核 的 数据 。 

Create Table ZGSH 

Select 身份 证 号 ,岗位 编号 ,笔试 成 绩 ,面试 成 绩 From GWCJB Where 资格 审核 ; 

由 于 Create Table 子 句 中 没有 描述 主键 ,因此 ,新 表 ZGSH 没有 主键 。 

【 例 4.63】 创建 一 个 岗位 与 申报 人 数 对 应 表 GWSB ,包含 岗位 编号 .岗位 名 称 .招聘 
人 数 和 申报 人 数 4 个 字段 ,主键 为 岗位 编号 。 其 中 申报 人 数字 段 为 4 位 整 型 ,其 余 字段 保 
留 GWB 中 的 相关 属性 ,并 存储 对 应 的 数据 。 

Create Table GWSB (申报 人 数 Int (4) ，Primary Key (岗位 编号 )) Rs 

Select 岗位 编号 ,岗位 名 称 , 人 数 as 招聘 人 数 ， 
Count (* ) Rs 申报 人 数 From GWB Natural Join GWCJB Group By 岗位 编号 ; 

综合 上 述 各 例 可 以 看 出 ,Create Table 子 句 可 以 是 一 条 能 完全 独立 执行 的 语句 或 其 中 
的 部 分 短语 。 设 计 创 建 表 与 查询 合并 的 语句 时 ,如 果 和 希望 新 表 有 主键 且 计 算 列 ( 如 招聘 
人 数 ) 属 性 更 明确 , 则 需要 在 Create Table 子 句 中 进行 详细 的 描述 。 


4.9.2 增加 记录 与 查询 语句 合并 


Insert 和 Replace 与 Select 语句 合并 ,将 查询 结果 的 数据 记录 添加 到 表 中 。 执 行 增加 
记录 与 查询 合并 语句 ,要 求 用 户 具 有 Select 和 Insert 两 种 权限 。 
(1) Insert 语句 格式 : 
Insert [Delayed |Low Priority | High Priority] 
[Into] < 表 名 >[( 舍 段 名 表 习 ] 
<Select 子 句 > 
[On Duplicate Key Update < 他 段 名 1 >=< 表 达 式 1 >…] 


(2) Replace 语句 格式 : 
Replace [Delayed ILow_Priority] 
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[Into] < 表 名 >[( 和 守 段 名 表 >)] 
<Select 子 句 > 

从 语句 格式 上 看 ,与 4.5 节 中 的 Insert 和 Replace 语句 比较 ,将 “Values( < 表达 式 
表 1>)…[,( < 表达 式 表 n> )]" 短 语 换 成 了 Select 子 句 , 共 同 拥有 的 短语 ( 如 Delayed、 
Low_Priority 和 字段 名 表 等 ) 作 用 、 要 求 和 用 法 基本 相同 ;从 增加 记录 方面 看 ,只 是 将 记录 
的 数据 源 改 成 了 Select 子 句 的 查询 结果 。 

这 两 条 合并 语句 的 共同 要 求 是 : Select 子 句 的 查询 结果 列 与 要 填写 的 字段 按 前 后 顺 
序 一 一 对 应 ,对 应 列 (字段 ) 的 名 称 、 数 据 类 型 可 以 不 同 ,但 是 ,查询 结果 中 各 列 的 数据 必 
须 是 可 转换 成 对 应 字段 的 数据 类 型 。 

【 例 4.64】 创建 申报 人 员 平 均 分 表 PJFB ,包含 身份 证 号 ( Char(18) ) .姓名 (VarChar 
(10) ) ,笔试 平均 分 (TinyInt) 和 面试 平均 分 ( TinyInt)4 个 字段 ,主键 为 身份 证 号 ,并 填写 
应 聘 人 员 的 相关 数据 。 

Create Table PJFB (身份 证 号 Char (18) Primary Key, 姓名 VarChar (10)， 

笔试 平均 分 TinyInt, 面试 平均 分 TinyInt); /* 创建 表 结 构 语句 * / 


Insert Into PJEB 。 /* 统计 并 填写 应 聘 人 员 平均 分 的 合并 语句 * / 
Select 身份 证 号 , 姓名 ,AVG (笔试 成 绩 ) ,AVG (面试 成 绩 ) 
From YPRYB Natural Join GWCJB Group By 身份 证 号 ; 
从 本 例 可 以 看 出 ,用 于 表 备份 和 数据 分 类 存储 时 ,增加 记录 与 查询 合并 语句 (需要 两 
条 语句 ) 远 不 如 创建 表 与 查询 合并 语句 ( 仅 一 条 语句 ) 实 用 和 灵活 。 要 将 多 个 表 的 数据 记 
录 合并 到 一 个 表 中 ,这 两 条 语句 配合 使 用 效果 更 好 。 
【 例 4.65】 假设 有 RYB1 和 RYB2 两 个 表 , 要 求 创建 RYB( 与 RYB1 同 结构 ) , 主键 
为 身份 证 号 ,将 RYB1 和 RYB2 两 个 表 的 数据 合并 到 RYB 中 。 


Create Table RYB (Primary Key (身份 证 号 )) Rs Select * From RYB1; 


Replace Into RYB Select * From RYB2; 


第 一 条 语句 创建 表 RYB 的 同时 将 RYB1 中 的 数据 记录 合并 到 RYB 中 ,第 二 条 语句 
不 再 需要 创建 表 , 直 接合 并 RYB2 中 的 数据 记录 到 RYB 中 。 


4.9.3 查询 语句 的 合并 


表 连 接 可 以 将 多 个 表 中 的 字段 组 织 到 一 个 表 ( 结果 ) 中 ,多 个 表 中 的 数据 记录 连接 成 
结果 表 中 的 一 个 记录 ,也 称 表 的 横向 连接 。Seleet 语句 (查询 结果 ) 合 并 是 对 多 个 查询 结 
果 中 的 数据 行进 行 纵向 连接 ,使 之 成 为 一 个 查询 结果 ,从 而 达到 多 个 表 中 的 数据 记录 纵向 
合并 的 目的 。 

语句 格式 : 


<Select 子 名 1 SUnion[All IDistinct] 
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<Select 子 句 2 >[ … Union[All IDistinct] <Select 子 句 n>] 


具体 规定 如 下 : 

(1) 各 条 Select 子 句 的 查询 结果 必须 有 相同 的 列 数 , 对 应 列 的 数据 类 型 可 以 不 同 , 但 
是 ,数据 类 型 之 间 必 须 可 以 自动 转换 。 

(2) Union[ Distinct] 在 合并 结果 中 重复 记录 仅 输出 一 次 ,而 Union Al 将 输出 全 部 数 
据 行 ,可 能 有 重复 的 数据 记录 。 

(3) 各 条 Select 子 句 的 列 名 (标题 ) 可 以 不 同 ,但 由 第 一 条 Select 子 句 中 的 列 名 确定 
合并 后 结果 的 列 名 。 

(4) 每 条 Select 子 句 都 是 一 条 能 独立 执行 的 语句 ,但 是 ,只 有 最 后 一 条 Select 子 句 后 
才 可 以 使 用 Order By < 列 名 > | < 列 号 > [ASC1DESC ] 短语 ,作为 合并 后 结果 的 排序 
规则 。 

【 例 4.66】 用 一 个 表 按 地 址 排序 输出 未 注销 的 公司 名 称 地址 .邮政 编码 以 及 应 聘 
人 员 的 姓名 ,通信 地 址 .邮政 编码 。 


Select 公司 名 称 , 地 址 ,邮政 编码 From 公司 表 Where Not 注销 /* 第 一 条 子 句 * / 


Union All /* 可 以 重复 记录 的 连接 符 * / 
Select 姓名 ,通信 地 址 ,邮政 编码 From YPRYB /* 第 二 条 子 句 * / 
Order By 地 址 ; 


合并 后 的 结果 中 3 列 的 名 称 分 别 是 第 一 条 子 句 中 的 公司 名 称 地址 和 邮政 编码 ,与 第 
二 条 子 句 的 列 名 无 关 。“ Order By 地 址 "用 于 说 明 在 合并 后 结果 中 按 地 址 列 升序 排列 , 输 
出 结果 如 表 4-10 所 示 。 


表 4-10 Select 语句 合并 的 结果 





























名 称 地 址 邮政 编码 
腾飞 总 公司 北京 市 中 关 村 100201 
王 丽 敏 北京 西城 区 德 外 大 街 4 号 100120 
食 府 快 餐 店 长 春 经 济 开发 区 130103 
李 丽 丽 长 春 前 进 大 街 2099 号 130012 
刘 德 厚 长 春 前 进 大 街 2699 号 130012 
赵 明 长 春 人 民 大 街 99 号 130021 
医大 一 院 长 春 市 朝阳 区 130012 
工商 前 进 支行 长 春 市 高 新 区 130012 
郝 帅 园丁 花园 9 号 楼 130054 








【 例 4.67】 用 一 个 表 按 岗位 名 称 排 序 输出 各 岗位 的 招聘 人 数 和 申报 人 数 ,招聘 和 申 


报 分 行 显示 。 
Select 岗位 编号 ，Concat (岗位 名 称 , "招聘 ') AS 名 称 , 人 数 From GWB /* 第 一 条 子 句 * / 
Union /* 无 重复 记录 合并 * / 
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Select GWB. 岗 位 编号 , Concat (岗位 名 称 , "申报 ") ,Count(* ) /* 第 二 条 子 句 * / 
From GWB Natural Join GWCJB Group By GWB. 岗 位 编号 Order By 2; 


执行 此 语句 ,输出 结果 如 表 4-11 所 示 。 
表 4-11 基本 查询 与 分 组 统计 纵向 连接 的 结果 









































岗位 编号 名 称 人 数 
B0003 岗 前 培训 师 招聘 2 
A0004 会 计 招聘 3 
BO0001 经 理 助理 招聘 3 
B0001 经 理 助理 申报 3 
B0002 理财 师 招聘 12 
BO002 理财 师 申报 4 
A0003 律师 招聘 3 
A0001 行 长 助理 招聘 
A0001 行 长 助理 申报 2 
A0002 银行 柜员 招聘 5 
A0002 银行 柜员 申报 3 


语句 中 Concat( 岗位 名 称 ,招聘 ' ) 是 将 两 个 字符 串 连 接 成 一 个 字符 串 的 函数 。 此 例 
中 将 基本 查询 的 结果 与 分 组 (Group By GWB. 岗位 编号 ) 统 计 的 结果 进行 纵向 合并 ,得 到 
一 个 查询 结果 。 结 果 中 第 二 列 的 列 标题 为 第 一 条 子 句 的 列 标题 。 表 中 未 加 灰色 底 纹 的 数 
据 行为 第 一 条 子 句 基本 查询 的 结果 ,加 了 灰色 底 纹 的 数据 行为 第 二 条 子 句 分 组 统计 的 
结果 。 


4.10 视图 及 其 应 用 


视图 是 依据 Select 语句 组 织 多 个 数据 表 的 一 种 映像 机 制 ,也 是 存储 于 数据 库 中 的 一 
类 对 象 一 一 虚拟 表 。 为 了 便于 管理 和 使 用 视图 , MySQL 提供 了 创建 ,修改 和 删除 视图 的 
有 关 语 句 。 


4.10.1 创建 视图 


视图 是 数据 库 中 的 对 象 ,在 使 用 视图 之 前 ,需要 运行 相关 语句 创建 视图 。 像 SQL 语 
句 一 样 ,可 以 在 命令 行 或 PHPMyAdmin 可 视 化 窗口 中 编辑 和 运行 创建 视图 的 语句 ,对 创 
建 视图 的 用 户 应 该 赋予 Select 和 Create View 权限 。 创 建 视图 的 语句 中 有 许多 短语 ,为 便 
于 理解 和 应 用 ,本 节 只 讲述 基本 语句 和 常用 短语 。 
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基本 语句 格式 : 


Create [ Or Replace ] View < 视图 名 >[ ( 列 名 称 表 ) ] 
Rs <Select 子 句 > 


【 例 4.68】 创建 包含 岗位 编号 、 面 试 平均 分 和 笔试 平均 分 的 视图 CWPJF。 
Create View GWPJF As 
Select 岗位 编号 ,AVG (面试 成 绩 ) As 面试 平均 分 ,AVG (笔试 成 绩 ) as 笔试 平均 分 
From GWCJB Group By 岗位 编号 Order By 岗位 编号 ; 

执行 该 语句 后 ,在 当前 数据 库 中 创建 一 个 视图 对 象 GWPJF ,其 中 包含 岗位 编号 面试 
平均 分 和 笔试 平均 分 3 列 信息 。 当 引用 视图 对 象 GWPJF 时 ,数据 将 按 岗位 编号 升序 
排列 。 

重复 执行 上 述 语句 时 ,由 于 视图 GWPJF 已 经 存在 ,因此 ,将 导致 系统 出 错 。 如 果 在 语 
句 中 再 加 Or Replace 短语 ,即使 新 视图 与 数据 库 中 的 某 个 视图 重 名 ,也 不 会 出 错 ,而 用 新 
定义 的 视图 覆盖 原 视图 。 

基本 语句 中 其 他 短语 有 下 列 含义 。 

(1) 视图 名 。 为 视图 命名 ,命名 规则 与 数据 表 命 名 规则 相同 。 

(2) 列 名 称 表 。 为 视图 中 各 列 命名 , 列 名 之 间 用 逗号 分 隔 , 列 与 表 中 字段 的 命名 规则 
相同 。 要 求 列 名 称 表 中 的 列 数 与 Select 子 句 查询 结果 中 的 列 数 一 致 ,并 按 前 后 顺序 一 一 
对 应 。 当 省 略 列 名 称 表 时 ,如 例 4.68 ,视图 中 的 列 数 及 各 列 名 称 由 Select 子 句 的 查询 结果 
确定 。 

(3) Select 子 句 。 创 建 视图 的 核心 ,用 于 定义 视图 中 的 数据 来 源 和 列 。Select 子 句 可 
以 是 任何 一 条 能 独立 运行 的 Select 语句 ,如 基本 查询 ,数据 排序 ,分 组 统计 、 查 询 舱 套 或 查 
询 合 并 等 ,甚至 Select 子 句 的 数据 源 ( From 短语 中 的 对 象 ) 还 可 以 是 另 一 个 视图 对 象 , 即 ， 
一 个 视图 可 以 是 另 一 个 视图 的 数据 源 。 


4.10.2 应 用 视图 


视图 与 表 都 是 数据 库 中 的 对 象 ,但 是 二 者 有 着 本 质 的 差异 。 表 中 除 存储 表 结 构 以 外 
还 存储 数据 记录 ,而 视图 中 只 存储 获取 表 中 数据 的 映像 机 制 , 主要 是 Select 语句 ,并 不 存 
储 数据 。 仅 当 引 用 视图 时 , 才 由 获取 数据 的 映像 机 制 从 其 数据 源 (如 表 ) 中 提取 数据 。 视 
图 在 许多 方面 扮演 着 数据 表 的 角色 ,起 到 数据 表 的 作用 ,因此 ,通常 也 称 之 为 虚拟 表 。 视 
图 主要 有 下 列 一 些 方面 的 应 用 。 


1. 作为 数据 源 使 用 


视图 是 虚拟 表 , 可 以 像 数据 表 一 样 作为 Select 语句 的 数据 源 使 用 。 
【 例 4.69】 利用 例 4. 68 中 创建 的 视图 GWPT ,输出 高 于 所 报 岗 位 笔试 平均 分 人 员 
的 身份 证 号 .岗位 编号 和 笔试 成 绩 。 


Select 身份 证 号 ,岗位 编号 ,笔试 成 绩 
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From GWCJB Natural Join GWPJE Where 笔试 成 绩 兹 试 平均 分 ; 


语句 中 的 数据 源 GWPJF 就 是 视图 ,起 到 表 的 作用 。 从 本 例 可 以 看 出 ,将 视图 作为 数 
据 源 ,可 以 将 比较 复杂 的 问题 分 解 成 多 步 ( 例 4. 68 和 例 4. 69 两 步 ) 实现 ,从 而 使 每 步 设 
计 思 路 更 清晰 ,SQL 语句 更 简单 。 视 图 往往 可 以 替代 骨 套 的 SQL 语句 解决 比较 复杂 的 问 
题 , 简 化 SQL 语句 。 


2. 作为 功能 模块 使 用 


视图 通过 Select 语句 组 织 和 集成 多 个 表 中 的 数据 ,对 数据 进行 统计 分 析 ,作为 一 个 对 
象 存储 于 数据 库 中 。 在 PHPMyAdmin 可 视 化 窗口 中 ,可 以 像 操作 系统 选项 或 工具 一 样 操 
作 视 图 ,执行 Select 语句 进行 数据 查询 和 统计 分 析 。 根 据 这 一 特点 ,可 以 将 一 些 常见 应 用 
要 求 设计 成 视图 ,以 便 将 每 个 视图 作为 一 个 程序 模块 使 用 ,通过 简单 的 操作 即 可 完成 数据 
查询 及 统计 分 析 任 务 ,达到 一 劳 永 逸 的 效果 。 

【 例 4.70】 设计 两 个 视图 : 一 个 包含 身份 证 号 .姓名 .岗位 编号 .岗位 名 称 、 笔 试 成 
绩 \ 面 试 成 绩 和 总 分 , 同 岗位 按 总 分 由 高 到 低 排序 ,视图 名 为 GRCJ; 另 一 个 包含 岗位 编号 、 
岗位 名 称 、 人 数 、 申 报 人 数 以 及 总 成 绩 最 高 分 最低 分 和 平均 分 ,视图 名 为 GWTJ。 


Create View GRCJ As 
Select 身份 证 号 ,姓名 ,岗位 编号 ,岗位 名 称 ,笔试 成 绩 ,面试 成 绩 ， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) As 总 分 
From YPRYB Natural Join GWCJB Natural Join WB 
Order By 岗位 名 称 ,总 分 DESC; 


Create View GWTU As 
Select 岗位 编号 ,岗位 名 称 , 人 数 ,Count (* ) as 申报 人 数 ， 
Max (笔试 成 绩 * 笔试 成 绩 比 例 /100 :+ 面试 成 绩 * (1 -笔试 成 绩 比例 /100) ) As 最 高 分 ， 
Min (笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100)) as 最 低 分 ， 
AVG (笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) ) As 平均 分 
From GWB Natural Join GWCJB Group By 岗位 编号 ; 
GRCJ 和 GWTJ 是 两 个 常见 数据 统计 分 析 的 视图 ,在 数据 库 中 单 击 视图 GRCJ .GWTJ 
或 者 通过 简单 的 Select 语句 都 可 查看 有 关 统 计 分 析 的 结果 。 
【 例 4.71】 通过 视图 CWTJ ,输出 岗位 编号 .岗位 名 称 \ 人 数 . 申 报 人 数 和 平均 分 ; 依 
据 视 图 GRCJ 和 GWTJ ,输出 获得 每 个 岗位 最 高 总 分 的 身份 证 号 .姓名 .岗位 编号 .岗位 名 
称 和 总 分 ;输出 高 于 所 报 岗位 平均 分 的 身份 证 号 .姓名 .岗位 编号 .岗位 名 称 和 总 分 。 


Select 岗位 编号 ,岗位 名 称 , 人 数 ,申报 人 数 ,平均 分 From GWTJ; 


Select 身份 证 号 ,姓名 ,岗位 编号 ,岗位 名 称 , 总 分 
From GRCJ Natural Join GWTJ Where 总 分 -最 高 分 ; 


Select 身份 证 号 ,姓名 ,岗位 编号 ,岗位 名 称 ,总 分 
From GRCJ Natural Join GWTJ Where 总 分 羡 均 分 ; 
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从 上 述 3 个 应 用 要 求 和 实施 语句 可 以 看 出 ,恰当 地 设计 和 运用 视图 ,往往 可 以 通过 简 
单 的 Select 语句 完成 一 些 较 复 杂 的 设计 任务 。 

视图 不 仅 可 以 作为 数据 查询 和 统计 分 析 的 数据 源 ,实质 上 也 可 以 作为 SQL 数据 操纵 
语句 ( Insert、Replace .Delete 或 Update ) 的 操作 对 象 ,通过 视图 间接 地 增加 修改 和 删除 表 
中 的 数据 记录 。 但 是 ,由 于 直接 操作 视图 ,实质 间接 操纵 表 中 数据 记录 的 过 程 过 于 烦琐 而 
不 被 常用 ,因此 ,本 书 省 略 了 这 方面 的 内 容 。 


4.10.3 ”维护 视图 


视图 是 数据 库 中 的 一 种 对 象 , 像 数 据 表 一 样 ,MySQL 也 提供 了 修改 和 删除 视图 的 语句 。 


1. 修改 视图 
执行 修改 视图 语句 的 用 户 必 须 具 有 Create View 和 Drop 权限 。 
语句 格式 ， 


Alter View < 视图 名 >[ ( 列 名 称 表 )] As <Select 子 句 > 


对 一 个 已 经 存在 的 视图 执行 Create Or Replace View < 视图 名 > [ ( 列 名 称 表 ) ] As 
< Select 子 句 > 语句, 本质 上 与 执行 Alter View 语句 功能 完全 相同 。 
【 例 4.72】 将 例 4.68 中 创建 的 视图 GWPJF 改 为 仅 含 岗位 编号 和 笔试 平均 分 的 视图 。 


Alter View GWPJF As 
Select 岗位 编号 ,AVG (笔试 成 绩 ) As 笔试 平均 分 
From GWCJB Group By 岗位 编号 Order By 岗位 编号 ; 
2. 删除 视图 
语句 格式 : 
Drop View [ If Exists ] < 视图 名 表 > 


执行 一 条 Drop View 语句 可 以 删除 多 个 视图 ,视图 名 之 间 用 逗号 分 隔 。 在 语句 中 加 芷 
Exists 短语 ,可 以 避免 因 删除 不 存在 的 视图 而 引发 系统 出 错 。 
【 例 4.73】 删除 视图 GWPJF、GRCJ 和 GWTJ 三 个 视图 。 


Drop View GWPJF, GRCJ,GWIJ; 


4.11 表 中 数据 的 导出 与 导入 


在 MySQL 中 ,可 以 将 表 中 的 数据 导出 到 Windows 中 常用 的 一 些 文档 中 , 供 其 他 软件 
使 用 和 进一步 处 理 。 同 样 ,也 可 以 将 其 他 软件 处 理 后 的 数据 导入 到 数据 表 中 ,成 为 数据 库 
中 的 数据 ,由 此 提高 数据 的 重用 性 。 
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4.11.1 导出 表 中 的 数据 


通过 Select 语句 附加 Into OutFile 短语 ,可 以 将 数据 表 中 的 数据 记录 或 统计 结果 导出 
到 其 他 文档 中 。 执 行 数据 导出 语句 的 用 户 必须 具有 Select 和 File 权限 。 
语句 常用 格式 : 
Select … Into OutFile < 文件 路 径 及 文件 全 名 > 
[ Fields [Terminated By ' < 数据 项 分 隔 符号 >'] 
[Enclosed By ' < 数据 项 包 庄 符 号 >']] 
[ Lines Terminated BY ' < 数据 行 分 隔 符号 >'] 


1. 文件 路 径 及 文件 全 名 


文件 路 径 及 文件 全 名 用 于 说 明 要 导出 的 文件 存储 位 置 (路 径 ) 及 包含 扩展 名 的 文件 
名 。 文 件 存储 路 径 中 的 文件 夹 及 文件 之 间 用 正 斜 杠 符号 (Z) 分 隔 ;文件 名 中 的 扩展 名 用 
于 说 明 要 导出 的 文件 类 型 。 目 前 的 MySQL 版 本 支持 Office 2007 以 前 版 本 的 Word 
(DOC) .Excel(XLS) 以 及 文本 (TXT) 等 类 型 文件 。 文 件 路 径 及 文件 全 名 需要 用 单 引号 或 
双 引 号 引起 来 。 
【 例 4.74】 将 每 个 岗位 编号 .岗位 名 称 .招聘 人 数 和 申报 人 数 按 岗位 编号 由 小 到 大 
导出 到 下 ;\RCZP\GWTJ. DOC 文件 中 ,并 编辑 成 表格 。 
Select 岗位 编号 ,岗位 名 称 , 人数 ,Count (* ) From GWB Natural Join GWCJB 
Group By GWB. 岗 位 编号 Order By 1 
Into OutFile 'E:/RCZP/GWTJ.DOC'; 
执行 此 语句 后 ,用 Word 打开 EE:\RCZP\GWTJ. DOC 文件 , 选 定 导出 后 的 全 部 内 容 , 单 
击 “ 插 入 "选项 卡 一 “表格 "组 一 “表格 "一 “文本 转换 成 表格 "选项 。 在 “将 文字 转换 成 表 
格 ”" 对 话 框 中 ,选择 列 数 为 4, 固定 列 宽 为 “自动 ” ,文字 分 隔 位 置 为 “ 制 表 符 ” ,最 后 单 击 
“确定 "按钮 , 即 可 将 其 转换 成 Word 表格 。 


2. Field 短语 


Field 短语 用 于 说 明 数据 项 的 表示 形式 ,选择 此 短语 后 ,至 少 要 使 用 下 列 一 个 短语 : 

(1) Terminated By ' < 数据 项 分 隔 符号 >' 。 指 定数 据 项 之 间 的 分 隔 符 号 ,默认 分 隔 
符号 为 制 表 符 (Tab) 。 在 导出 Word 或 文本 文件 时 ,一 般 用 制 表 符 (Tab) 、 竖 线 (|) 或 逗号 
作为 分 隔 符号 ;在 导出 XLS 文档 时 ,用 制 表 符 作为 分 隔 符号 ,可 以 使 Excel 表格 与 查询 的 
输出 结果 按 列 对 应 ,用 其 他 符号 可 能 使 查询 结果 的 所 有 列 变 成 Excel 表格 中 的 一 列 。 

(2) ENClosed By ' < 数据 项 包 庄 符号 > " 。 指 定 每 个 数据 用 什么 符号 (如 双 引 号 , 单 
引号 等 ) 括 起 来 ( 包 右 ) ,数据 项 默认 无 包 右 符号 。 在 导出 文本 文件 时 ,有 时 用 双 引 号 将 数 
据 项 引起 来 。 
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3. Lines Terminated By ' < 数据 行 分 隔 符号 > ' 短语 


此 短语 用 于 说 明 数 据 行 之 间 的 分 隔 符号 。 在 导出 DOC 和 XLS 文档 时 ,默认 每 条 记 
录 为 一 行 数据 ;在 导出 文本 文件 (TXT) 时 ,导出 的 全 部 数据 占 一 行 。 
【 例 4.75】 将 GWCJB 中 的 全 部 数据 导出 到 文本 文件 GWCJB. TXT 中 ,每 个 数据 记 
录 占 一 行 ,数据 项 之 间 用 逗号 分 隔 ,每 个 数据 用 双 引 号 引起 来 。 
Select * From GWCJB 
Into OutFile 'E:/RCZP/CJIB.DOC' 
Fields Terminated By ',"' Enclosed By '"'; 
执行 此 语句 后 ,用 Word 软件 打开 下: \RCZP\CJB. DOC 文件 , 选 定 导出 后 的 全 部 内 
容 , 通 过 “复制 "和 “粘贴 ” ,将 导出 的 数据 粘贴 到 记事 本 软件 中 ,保存 文件 名 为 GCWCJB. 
TXT。 如 果 将 语句 中 的 下 :/RCZP《ZCJB. DOC 写成 上 :/RCZPZCJB. TXT, 则 CJB. TXT 中 的 
数据 不 分 行 。 


4.11.2 导 人 和 人 表 中 的 数据 


向 表 中 导入 数据 的 主要 目的 是 将 其 他 软件 处 理 后 的 数据 保存 到 数据 库 中 。 执 行 数据 
导入 语句 的 用 户 必 须 具 有 数据 的 Insert 和 File 权限 。 
语句 常用 格式 : 
Load Data InFile < 文件 路 径 及 文件 全 名 >Into Table < 表 名 > 
[Fields [Terminated By ' < 数据 项 分 隔 符号 >'] 
[Enclosed By ' < 数据 项 包 右 符号 >']] 
[Lines Terminated By ' < 数据 行 分 隔 符号 >"] 


[( 字段 名 表 习 ] 
文件 路 径 及 文件 全 名 Fields 和 Lines 短语 的 作用 及 要 求 同 前 ; 表 名 用 于 指出 已 经 存 
在 的 目标 表 。 


字段 名 表 用 于 说 明 要 导入 值 的 字段 名 ,省略 此 项 表示 填写 表 中 的 全 部 字段 。 但 是 , 当 
被 导入 的 数据 列 数 不 足 时 ,多 余 字 段 的 值 由 系统 自动 十 人 ,请 参考 4.5.1 节 的 “5. 自动 填 
写 的 字段 " 。 

【 例 4.76】 在 文本 文件 E:\RCZP\GW. TXT 中 存储 有 关 岗 位 的 数据 ,每 个 岗位 的 数 
据 占 一 行 ,数据 项 之 间 用 逗号 分 隔 , 将 其 导入 到 GWB 中 。 


Load Data InFile 'E:/RCZP/GW.TXT" Into Table GWB Fields Terminateq By ','; 


导入 数据 时 ,被 导入 的 数据 格式 一 定 要 规范 ,否则 ,可 能 导致 系统 出 错 数据 串 项 、 数 
据 丢 失 或 出 现 空 记录 等 问题 ,因此 ,导入 数据 后 要 认真 复查 ,确保 数据 的 正确 性 。 

总 之 ,本 章 通 过 大 量 的 应 用 实例 ,讲述 了 数据 库 的 物理 设计 过 程 与 SQL 语句 的 常用 
语法 .功能 和 应 用 技巧 ,只 要 掌握 了 这 些 要 领 和 技术 ,就 能 灵活 运用 SQL 语句 ,驾驭 数据 
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库 管 理 系统 ,进行 数据 统计 和 分 析 , 将 数据 库 技术 应 用 到 自己 的 专业 或 相关 领域 中 ,充分 
发 挥 数据 库 技术 的 强大 作用 ,为 开发 和 设计 实用 的 网 络 应 用 程序 打下 坚实 的 基础 。 

当然 ,要 使 数据 库 能 在 网 络 应 用 程序 中 发 挥 更 大 的 作用 ,收获 一 劳 永 逸 的 实用 效果 ， 
增 大 受众 面 ,还 需要 进一步 学 习 有 关 网 页 及 程序 设计 方面 的 技术 和 方法 ,只 有 SQL 语句 
与 应 用 程序 有 机 地 结合 起 来 ,才能 为 网 络 应 用 程序 增添 更 大 的 活力 。 


习 题 


一 、 填 空 题 


1. SQL 由 _ 中、 加 、 回 和 _@ 4 种 子 语言 组 成 , Create Table 语句 属 
于 _@ ,Update 语句 属于 _@) ,Select … From 语句 属于 _@ ,Grant 和 Revoke 语句 
局 于 二 。 

2. SQL 的 数据 定义 语言 由 四 Table、 @@ _Table 和 四 _ Table 3 条 语句 构成 。 

3. 在 Create Table 电子 商品 (类 别 Char( 10 ) Primary Key ,编码 Char(6 ) Primary Key， 
商品 + 名 称 VarChar (20)) 语句 中 ,有 _ 中 处 错误 ,正确 的 语句 应 该 是 Create 
Table 亏本 

4. 多 次 执行 Create Table 论坛 表 (文章 序号 Int Auto_Increment Primary Key ,作者 
VarChar(20) Default ' 匿 名 ' ,文章 内 容 Text, 更 新 时 间 TimeStamp, 作者 简介 Text ) 语句 ， 
系统 会 _QD_ ,加 _@@ 短语 可 以 避免 发 生 这 种 事情 。 第 一 次 执行 这 条 语句 后 , 当 系 统 时 
间 是 2017 年 1 月 8 日 下 午 2 点 3 分 5 秒 时 ,如 果 立 即 执行 Insert 论坛 表 Values ( Default ， 
Default ， 人 才 招 聘 ……” ，Default，Default) 语 句 , 则 新 增加 记录 的 文章 序号 为 _@ , 作 
者 为 _@ ,更 新 时 间 为 _@) ,作者 简介 为 _@ _;3 秒 钟 后 又 执行 Insert 论坛 表 ( 文章 
内 容 ) Values (' 招聘 人 员 …… ' ) 语句, 则 第 2 个 记录 的 文章 序号 为 _@ ,作者 为 
_ @ ,更 新 时 间 为 _@ ,作者 简介 为 四 。 

5. 在 MySQL 中 ,11 Div 4 的 值 是 QD _;11 % 3 的 值 是 _@ _,"1.5E2' + '5 元 ' 的 
值 是 @ 。 

6. 为 了 使 Insert 语句 增加 关键 字 值 重复 的 记录 时 不 引发 系统 出 错 ,应 该 加 QD 短 
语 ;在 Insert 语句 中 用 短语 ,执行 一 次 可 以 增加 多 个 记录 ,用 _@ 短语 ,执行 一 次 
只 能 增加 1 个 记录 。 除 Insert 语句 以 外 ,还 有 ”多 ”语句 能 向 表 中 增加 数据 记录 。 

7. 如 果 GWCJB 中 有 多 条 记录 , 则 执行 Select avg( 笔试 成 绩 ) As 平均 分 , Max( 笔试 
成 绩 ) As 最 高 分 From GWCJB 语句 ,将 输出 _@ 行 、@@ 列 数据 。 

8. 在 Select 语句 中 ,对 查询 结果 进行 排序 ,应 该 加 ”QD 短语 ;对 数据 进行 分 组 统计 
分 析 , 应 该 用 _@@ 短语 ;消除 查询 结果 中 的 重复 记录 ,应 该 用 _@ 短语 ;对 查询 结果 进 
一 步 筛选 用 _@ 四 “短语 ;将 查询 结果 存储 到 一 个 文件 中 ,应 该 用 _@@_ 短语 。 

9. 在 Select * From GWCJB Where < 条 件 > 语 句 中 ,条 件 为 _Q 输出 岗位 编号 为 
B0001 的 记录 ;条 件 为 _@ 输出 面试 成 绩 在 50 ~ 59 之 间 的 记录 ;条 件 为 _@ 输出 高 
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于 面试 成 绩 平均 分 的 记录 。 

10. 在 Select * From YPRYB Where < 条 件 > 语 句 中 ,条 件 为 _Q@ 输出 女士 记录 ; 
条 件 为 _@@ ”输出 姓名 中 含 “国庆 ”的 记录 ;条 件 为 _@ 输出 通信 地 址 中 含 北京 上海 
或 深圳 的 记录 ;条 件 为 ”_@ 输出 通过 资格 审核 的 记录 。 

11. 在 Select * From YPRYB Natural Join GWCJB 语句 中 , 隐 含 说 明 YPRYB 与 
GWCJB 的 连接 条 件 是 QD) ;Select x* From GWB Natural Join GWCJB 语句 中 , 隐 含 说 明 
GWB 与 GWCJB 的 连接 条 件 是 ”@ ;执行 Select * From YPRYB Left Join GWCJB On 
PRYB. 身份 证 号 =GWCJB. 身份 证 号 语句 时 ,对 于 没有 申报 任何 岗位 的 人 员 ,在 查询 结果 
中 对 应 岗位 编号 列 的 值 是 _@ 。 

12. Select AVG( 笔试 成 绩 ) From GWCJB Group By 岗位 编号 ,作为 子 查询 语句 使 用 ， 
当 GWCJB 为 空 表 时 , 子 查 询 的 结果 为 ”中 _; 当 GWCJB 中 有 100 个 记录 ,10 个 不 同 的 岗 
位 时 , 子 查 询 的 结果 为 ”@ “个 数据 。 可 以 参与 该 子 查询 结果 的 运算 符号 有 @ 。 

13. 输出 面试 成 绩 高 于 所 报 岗位 平均 分 的 身份 证 号 .姓名 岗位 编号 .岗位 名 称 和 笔 
试 成 绩 的 语句 是 : Select 身份 证 号 , 姓名 ,岗位 编号 ,岗位 名 称 ,笔试 成 绩 From YPRYB 
中 _cGWCJB _®@ G6wB Where _@ ( Select 由 From GWCJB As CJB Where 

©® )。 

14. 在 MySQL 中 , 允许 一 条 语句 中 写 入 另 一 条 SQL 语句 ,将 这 种 语句 形式 称 为 
_@@_。 在 舱 套 的 语句 中 ,以 _@ 为 主语 句 的 Where 短语 中 人 允许 嵌 套 子 语句 ,还 可 以 
在 _@ 主语 句 的 有 关 表达 式 中 帜 套子 语句 , 子 语句 由 _@_ 语 句 构成 。 

15. 有 关 SQL 语句 合并 ,语句 由 @@ 语句 和 另 一 条 Select 语句 构成 。 语 句 Select 
地 址 From 公司 表 _@ _Select 通信 地 址 From YPRYB 可 能 输出 重复 的 记录 ;语句 Select 
地 址 From 公司 表 ”@”Select 通信 地 址 From YPRYB 输出 没有 重复 记录 ;合并 后 结果 只 
有 一 列 , 列 名 为 _@ 。 











二 、 单 选 题 
1. MySQL 是 ( 
A. OS B. DBMS C. 报表 软件 D. Web 服务 器 
2. ( ) 不 属于 SQL 的 数据 定义 语言 。 
A. Create Table…  B. Alter Table  C. Update … D. Drop Table … 
3. 选择 正确 的 内 容 ,完成 语句 Create Table 销售 (( ) ,名 称 Char(20) ,数量 Int， 
单价 Real) 。 


A. 序号 Int Auto_Increment 
B. 序号 Int Auto_Increment Primary Key 
C. 序号 Int Auto_Increment, 记 录 号 INT Auto_Increment 
D. 序号 Char(6) Auto_Increment Primary Key 
4. 要 创建 成 绩 表 , 含 学 号 Char(8) ,课程 号 Char(4) 和 成 绩 mnt 三 个 字段 ,学 号 和 课程 
号 共同 构成 主键 ,正确 的 SQL 语句 是 Create Table 成 绩 表 ( js 
A. 学 号 Char(8) ,课程 号 Char(4) Primary Key ,成 绩 Int 
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B. 学 号 Char(8) Primary Key ,课程 号 Char(4) Primary Key ,成 绩 Int 
C. 学 号 Char(8) ,课程 号 Char(4) Primary Key( 学 号 ,课程 号 ) ,成 绩 Int 
D. 学 号 Char(8) ,课程 号 Char(4) ,成 绩 Int,Primary Key( 学 号 ,课程 号 ) 
5. 在 Create Table 语句 中 ,(”@”) 必 须 与 Primary Key 结合 使 用 ,(”@@ ) 需 要 其 


他 表 及 其 字段 。 
A. Not Null B. Auto_Increment 
C. Primary Key D. Foreign Key 


6. 在 Alter Table 语句 中 ,加 (”Q ) 短 语 能 增加 字段 ,( ”名 ”) 短 语 能 删除 外 键 ， 
( 图 ) 短 语 能 修改 字段 名 ,(”@”) 短 语 能 修改 表 名 ,( ”B® ”) 短 语 能 修改 字段 的 默 
认 值 。 
A. Add B. Drop C. Rename D. Change 
E. Modify F. Alter 
7. 当 GWB 表 有 主键 且 非 空 时 ,执行 Create Table GWB1 Like GWB, 对 GWB1 的 结论 
是 ( 中 ) ;执行 Create Table GCWB1 As Select * From CWB ,对 GWB1 的 结论 是 ( 四 
) 。 


A. 无 主键 的 空 表 B. 有 主键 的 空 表 
C. 无 主键 的 非 空 表 D. 有 主键 的 非 空 表 


8. 执行 Create Table XS( BH Char(5) ,SL Int Default 1 ,时 间 ( @D )) 和 Insert Into 

XSValues('00001', Default,(”@@” ) ) 语 名 ,能 将 系统 的 日 期 时 间 填 到 时 间 字 段 中 。 
A. Null B. Date C. Time D. DateTime 
E. TimeStamp F. Default G. CurDate( ) H. CurTime( ) 

9. 通过 Create Table 课程 (课程 号 Char(3) Primary Key, 课程 名 VarChar( 30))、 
Create Table 学 生 ( 学 号 Char(8) Primary Key, 姓名 VarChar(10)) 和 Create Table 成 绩 
(学 号 Char(8) , 课程 号 Char(3) ,分 数 TinyInt，Foreign Key( 课 程 号 ) References 课程 ( 课 
程 号 )， Foreign Key( 学 号 ) References 学 生 ( 学 号 ) ) 创建 的 3 个 表 。 当 执行 Drop Table 
语句 删除 这 3 个 表 时 ,操作 表 的 正确 顺序 是 ( )。 


A. 成 绩 .课程 和 学 生 B. 课程 成绩 和 学 生 
C. 课程 ,学生 和 成 绩 D. 学 生 ,课程 和 成 绩 


10. 执行 Create Table 课程 (编号 Char(3) Primary Key, 名 称 VarChar(30) ) 创 建 的 课 
程 表 ,( ) 与 Replace Into 课程 Values('301' ,英语 ' ) 语 句 的 功能 完全 相同 。 
A.，Insert Into 课程 Values ('301' ,' 英 语 ' ) 
B. Insert Into 课程 (编号 ,名 称 ) Values ('301' ,' 英 语 ' ) 
C. Insert 课程 Values ('301' 英语 ) 
.Insert 课程 Values ('301' ,英语 ) On Duplicate Key Update 名 称 = ' 英 语 ' 
11. 在 题 10 建立 的 课程 表 中 ,假设 已 经 存在 编号 为 301 的 记录 ,执行 msert 语句 时 加 
( ) 短语 使 之 能 修改 数据 而 不 引发 系统 出 错 。 
A. Delayed B. Low_Priority 
C. On Duplicate Key Update D. If Exists 


已 
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A. 
B. 
C. 
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A. 
C. 


D. 


. 在 ( 


A. 
心 


. 在 Delete From GWCJB 中 加 ( ) 短语 能 删除 表 中 的 部 分 记录 。 


Where < 条 件 > B. When < 条 件 > 
While < 条 件 > D. FOR < 条 件 > 


.Select * From YPRYB Natural Join GWCJB 输出 ( sa 


YPRYB 表 中 所 有 字段 
两 个 表 中 字段 的 并 集 


B. GWCJB 表 中 所 有 字段 
D. 两 个 表 中 字段 的 交集 


. 在 Select … From YPRYB As  … 语 句 中 ,( ) 正确 。 


Where 短语 中 可 以 包含 YPRYB. 姓名 
Where 短语 中 可 以 包含 工 . 姓名 

Select 表达 式 中 可 以 包含 YPRYB. 姓名 
Order By 中 可 以 包含 YPRYB. 姓名 


. 在 SQL 中 ,与 表达 式 “ 成 绩 Between 0 And 60” 功 能 相同 的 表达 式 是 ( js 


成 绩 > =0 And 成 绩 < =60 
成 绩 < =0 Or 成 绩 > =60 


B. 成 绩 >0 And 成 绩 < 60 
D. 成 绩 > =0 Or 成 绩 < =60 


. Select * From YPRYB Where( ) 语 句 能 输出 姓 “ 龙 "(姓名 中 首 字 ) 的 全 部 人 


' 龙 % ' Like 姓名 B. 姓名 Like ' 龙 % 


. 姓名 Like ' 龙 _' D. 姓名 RLike ' 龙 ' 


) 语 句 能 输出 各 个 岗位 编号 .笔试 最 高 分 及 获得 此 成 绩 的 身份 证 号 。 


. Select 岗位 编号 ,Max( 笔试 成 绩 ) ,身份 证 号 From GWCJB Group By 岗位 编号 
. Select 岗位 编号 ,笔试 成 绩 ,身份 证 号 From GWCJB Where 笔试 成 绩 = Max( 笔 


试 成 绩 ) 


.Select 岗位 编号 ,笔试 成 绩 ,身份 证 号 From GWCJB Where 笔试 成 绩 = ( Select 


Max( 笔试 成 绩 ) From GWCJB As CJB Where CJB. 岗位 编号 = GWCJB. 岗位 
编号 ) 


. Select 岗位 编号 ,笔试 成 绩 ,身份 证 号 From GWCJB Having 笔试 成 绩 = Max 


(笔试 成 绩 ) 
) 语 句 正确 。 


. Delete From GWCJB Where 笔试 成 绩 < ( Select AVG (笔试 成 绩 ) From 


GWCJB) 


. Update GWCJB Set 笔试 成 绩 = (Select MAX( 笔试 成 绩 ) From GWCJB) 
. Update GWCJB Set 笔试 成 绩 =0 Where 笔试 成 绩 < ( Select AVG( 笔试 成 绩 ) 


From GWCJB) 
Select * From GWCJB Where 笔试 成 绩 < ( Select AVG (笔试 成 绩 ) From 
GWCJB) 
) 表 达 式 中 不 能 使 用 Avg 和 Sum 等 统计 函数 。 
Select < 表达 式 > B. Where < 表达 式 > 
Having < 表达 式 > D. 子 查询 的 Select < 表达 式 > 


((69 基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


编号 = GWB. 岗位 编号 ) 语 句 时 , 子 查询 被 执行 了 ( 
B. 100 
) 引 发 系统 出 错 。 


( 


20. 假设 GWB 中 有 100 个 岗位 ,其 中 有 40 个 岗位 已 经 有 人 申报 ,执行 Select * From 
GWB Where 岗位 编号 Not In (Select Distinct 岗位 编号 From GWCJB Where GWCJB. 岗位 


A.1 
21. 下 列 语句 中 ,执行 ( 


) 次 。 
C. 40 D. 60 


A. Create Or Replace View 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 
B.Create Or Replace View 岗位 (岗位 编号 ) As Select 岗位 编号 , 岗位 名 称 From 


GWB 


C，Create Table If Not Exists 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 
D.Create Table If Not Exists 岗位 (岗位 编号 Char(5) Primary Key) As Select 岗 
位 编号 , 岗位 名 称 From GWB 


22. GWB 非 空 ,执行 ( 


) 语 句 产生 的 对 象 中 包含 数据 记录 。 


A. Create View 岗位 As Select * From GWB 

B. Create Or Replace View 岗位 As Select * From GWB 
C. Create Table 岗位 Like GWB 

D. Create Table 岗位 As Select * From GWB 


、 多 选 题 

1. 在 Create Table 语句 中 ,( 
A. Primary Key 
D. Unique 

2. 在 Create Table 语句 中 ,( 


A. Constraint 


B. Foreign Key 
E. Index 


B. Foreign Key 


) 短语 能 创建 索引 。 


C. References 


) 短 语 能 定义 表 的 关键 字 。 
C. Primary Key 


D. Index E. Unique 

3. 在 SQL 语句 中 ( 。  ”) 内 容 左右 至 少 一 个 空格 。 
A. + B: 三 C. From D. Where 
E. Or F. Group By 


4. 执行 语句 Create Table CJB (学 号 Char (8), 课程 名 Char(30) ,成 绩 TinyInt 
Unsigned Default 0,Primary Key( 学 号 ,课程 名 ) ,Index XH (学 号 ) ,Index (课程 名 ) ) ,产生 
的 索引 名 称 ( 键 名 ) 有 ( ” )。 


A. 学 号 B. 课程 名 C. XH 
D. Index E. Primary 
5. 下 列 SQL 语句 中 ,( 中 ) 属 于 数据 定义 语言 ,( 四 ) 属于 数据 操纵 语言 ， 





@，) 属 于 数据 查询 语言 。 
A. Select… 
E. Insert… 
I. 创建 表 与 查询 语句 合并 
K. 查询 语句 的 合并 


B. Create Table … 
F. Replace … 


C. Alter Table  D. Drop Table … 
G. Update … H. Delete … 
本 增加 记录 与 查询 语句 合并 
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6. 填写 用 户 执行 语句 时 应 该 具有 的 权限 : 主语 句 是 Update 的 嵌 套 语句 ( 四 ), 主 
语句 是 Delete 的 嵌 套 语句 (”@@， ) ,主语 句 是 Select 的 柑 套 语句 (”@”) ,创建 表 与 查 
询 合 并 的 语句 ( 四 ), 增 加 记录 与 查询 合并 的 语句 ( 名 ), 数 据 导出 语句 
( @ ), 数 据 导 入 语句 ( @ )。 


A. Select B. Create C. Alter D. Drop 
E. Insert F. References G. Update H. Delete 
I. File 

7. 下 列 语句 中 ,( ”中 ) 能 创建 表 ,(”@@ ”) 能 向 表 中 添加 数据 记录 。 
A. Create Table … B. Create Table .… Select … 
C. Replace Into … D. Replace Into … Select:: 
E. Insert Into … Select … 


8. Create Table 学 生 + 奖学金 (学 号 Char(10) Primary Key ,姓名 VarChar( 10) ,年 度 
Char(4) Primary Key ,奖励 /金额 SmallInt) 语 句 , 可 能 错 在 ( Ya 


A. 表 名 不 能 为 汉字 
B. 表 名 中 有 加 号 应 该 用 左 单 引号 引起 来 
C. 奖励 /金额 可 以 改 为 奖励 金额 
D. 奖励 /金额 应 该 改 为 奖励 /金额 ` 
E. 出 现 两 个 Primary Key 短语 
F. 关键 字 的 值 不 唯一 
9. 关于 数据 表 , 正 确 的 叙述 是 (。””)。 
A. 将 不 含 字段 的 表 称 为 空 表 B. 将 不 含 数据 记录 的 表 称 为 空 表 
C. 一 个 表 中 可 含 多 个 主 属性 D. 一 个 表 最 多 只 有 一 个 主键 
E. 表 可 以 没有 主键 F. 表 必 须 有 外 码 
10. 在 一 条 Create Table 语句 中 ,(，@ ) 短 语 最 多 能 出 现 一 次 ,(，@@ ) 用 于 定义 
主键 。 
A. Unsigned B. Auto_Increment 
C. Primary Key D. Foreign Key 
E. Null 
11. 执行 ( 。 ”) 语 句 能 更 改 表 的 名 称 。 
A. Alter Table GWB Change GW B. Alter Table GWB Rename GW 
C. Alter Table GWB Modify GW D. Alter Table GWB Alter GW 


E. Rename Table GWB To GW 
12. 对 于 用 语句 Create Table LB(LBM Char(3) Primary Key, LBMC VarChar(20)) 和 
Create Table SP( LBM Char(3),SPM Char(3), SPMC VarChar(50 ) , Primary Key (LBM, 
SPM) ) 创 建 的 两 个 表 LB 和 SP,( ”) 有 错误 。 
A. Select LBM, LBMC, SPMC From LB ,SP Where LBM = SP. LBM 
B. Select LB. LBM, LBMC, SPMC From LB Join SP On LB. LBM = LBM 
C. Select LBM, LBMC, SPMC From LB Natural Join SP 
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.Insert LB Values("001' , "计算 机 ' ) 执行 两 次 
.Replace LB Values('001' ,计算 机 ' ) 执 行 两 次 
.Replace LB Values (Null， 笔 记 本 ' ) 

G. 


Replace LB Values (' 笔 记 本 ' ) 
LB 中 无 LBM 为 A01 记录 ,Insert SP Values(' A01' ,'001' 联想 2000' ) 


13. 对 于 用 语句 Create Table SP(SPM Char(3 ) Primary Key, SPMC VarChar(50) ,DJ 
Real Unsigned) 和 Create Table XS( XH Int Auto_Increment Primary Key, SPM Char(3 ) ,SL 
Int, Foreign Key( SPM) References SP (SPM) On Delete Cascade On Update Cascade ) 创建 
的 两 个 表 SP 和 XS, 在 SP 中 有 SPM 为 001 而 没有 A01 记录 的 情况 下 ,(  ) 有 错误 。 


.Insert SP Values('001' , ' 打 印 机 ' ) 

.Replace SP Values('001' , ' 打 印 机 ' ) 

.Insert SP( SPMC,SPM) Values(' 打 印 机 ','001') 
.Replace SP( SPMC ,SPM) Values(' 打 印 机 ' ,"001' ) 
.Insert SP Values('001' ，' 打 印 机 ' ，1000) 
.Replace SP Values('001 ， 打 印 机 ' ,1000) 

. JInsert XS Values( Default,'001' ,3) 

. Insert XS Values( Default,’' A01' ,3) 

. Replace XS Values( Default,'001’ ,3) 

. Replace XS Values( Default,’ A01' ,3) 


14. 对 于 用 语句 Create Table 课程 (课程 号 Char(3) Primary Key, 课程 名 VarChar 
(50)) 和 Create Table 成 绩 (学 号 Char(8) ,课程 号 Char(3) ,分 数 TinyInt, Foreign Key 
(课程 号 ) References 课程 (课程 号 ) On Delete Cascade On Update Cascade) 创建 两 个 表 ， 
在 课程 和 成 绩 表 中 均 有 课程 号 为 001 的 记录 ,而 没有 课程 号 为 999 的 记录 ,( 〇 @ ) 能 


正确 执行 , ( 





@) ) 同 时 操作 两 个 表 。 如 果 不 写 上 述 语句 中 的 On Delete Cascade 和 On 


Update Cascade ,其 他 条 件 不 变 , 则 (”@”) 能 正确 执行 。 


. Replace 成 绩 Values('99170101' ,'001', 85) 

. Replace 成 绩 Values('99170101' ,'999' ,85) 

.Insert 课程 Values('999' ， 大 学 计算 机 ' ) 

.Replace 课程 Values( "999' ， 大 学 计算 机 ' ) 

.Delete From 课程 Where 课程 号 ='001' 

.Delete From 成 绩 Where 课程 号 = '001' 

. Update 成 绩 Set 课程 号 = '999” Where 课程 号 = '001' 
.Update 课程 Set 课程 号 ='999' Where 课程 号 = '001' 


15. 对 于 用 Create Table XS (BH Char(5) Primary Key, SL It Default 1, 时间 
TimeStamp ) 语 句 创建 的 表 XS ,已 经 有 BH 为 00001 的 数据 记录 ,再 执行 ( ) 能 将 系统 
的 日 期 时 间 填 到 时 间 字 段 中 。 


A. 
B. 


Insert Into XS Values( "00001 ,2 ,Default) 
Replace Into XS Values( "00001 ,2, Default) 
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. Delete From XS Where BH = '00001” And 时 间 = Now() 

. Update XS Set SL =3 Where BH = 00001” 

.Select 时 间 From XS Where BH = '00001” 

. Replace Into XS( BH) Values('00002’) 
G. Insert Into XS( BH) Values('00002’') 

16. 下 列 SQL 语句 中 ,( 中 ) 能 向 表 中 添加 记录 ,(”@@ ) 能 修改 表 中 的 数据 。 

A. Insert … B. Delete … C. Replace … D. Update … 
E. Select … 

17. 执行 语句 Create Table 课程 (课程 号 Char(3) Primary Key, 课程 名 VarChar 
(30) ) ,Create Table 学 生 (学 号 Char(8) Primary Key, 姓名 VarChar(10) ) 和 Create Table 
成 绩 (学 号 Char(8) , 课程 号 Char(3 ) ,分 数 TinyInt，Foreign Key (课程 号 ) References 课 
程 (课程 号 ) ，Foreign Key( 学 号 ) References 学 生 ( 学 号 ) ) 创建 3 个 表 , 要 在 成 绩 表 中 增 
加 学 号 为 99170101 .课程 号 为 001 和 分 数 为 85 的 记录 (此 前 没有 ) ,在 学 生 表 中 有 学 号 为 
99170101 ,课程 表 中 有 课程 号 为 001 的 记录 情况 下 ,( ”四 ) 组 语句 能 正确 执行 ;在 学 生 
表 中 无 学 号 99170101 ,课程 表 中 无 课程 号 001 的 记录 情况 下 ,(”@@”) 组 语句 能 正常 运 
行 ,不 引发 系统 出 错 。 

A. Replace 成 绩 Values('99170101  ,"001 , 85) 

B. Insent 成 绩 Values('99170101' ,"001' ,85) 

C. Insert 课程 Values('001' ， 大 学 计算 机 ' ) 
Insert 成 绩 Values( '99170101' ,'001', 85 ) 
Insert 学 生 Values('99170101' ， 魏 来 ) 

D， Insert 成 绩 Values('99170101' ,'001', 85) 
Insert 课程 Values( '001' ,大 学 计算 机 ' ) 
Insert 学 生 Values( '99170101' ， 魏 来 ' ) 

了 上，Insert 学 生 Values('99170101' ,' 魏 来 ' ) 
Insert 课程 Values('001',' 大 学 计算 机 ' ) 
Insert 成 绩 Values('99170101' ,'001', 85) 

F. Replace 课程 Values('001' ,大 学 计算 机 ' ) 
Replace 成 绩 Values('99170101' ,"001 , 85) 
Replace 学 生 Values('99170101' ， 魏 来 ) 

G. Replace 成 绩 Values( "99170101' ,001' , 85) 
Replace 课程 Values('001' ,大 学 计算 机 ' ) 
Replace 学 生 Values('99170101' ,' 魏 来 ' ) 

H. Replace 学 生 Values( "99170101' ， 魏 来 ' ) 
Replace 课程 Values('001' ,' 大 学 计算 机 ' ) 
Replace 成 绩 Values('99170101' ,'001', 85) 

18. 由 Create Table 课程 (编号 Char(3) Primary Key, 名 称 VarChar( 30) ) 创 建 的 课程 
表 , 当 表 中 有 编号 为 301 的 记录 时 ,(， 中” ) 些 语句 的 功能 完全 相同 ,并 无 错误 ;在 表 中 
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还 没有 编号 为 301 的 记录 时 ,(”@”) 些 语句 的 功能 完全 相同 。 
AInsert Into 课程 Value('301' ,' 英 语 ' ) 
.Replace 课程 Value( '301' ,英语 ' ) 
.Insert 课程 Value ('301 , "英语 ' ) On Duplicate Key Update 名 称 =' 英 语 ' 
.Replace 课程 Value( '301' ,英语 ) On Duplicate Key Update 名 称 =' 英语 
.Update 课程 Set 名 称 =' 英 语 ' Where 编号 ='301" 
. Update 课程 Set 编号 ='301' Where 名 称 = ' 英 语 ' 
19. 在 执行 Select 语句 或 合并 语句 时 。 加 ( ) 短语 能 确保 查询 结果 中 没有 重复 


中 


A. Distinct B. Union All C. Where D. Order By 
E. Group By F. Having G. Union 
20. 执行 Select * From YPRYB Where(  ) 语 句 。 输 出 1999 和 2000 年 出 生 的 人 


.Mid( 身份 证 号 ,7,4) Between 1999 And 2000 
.Mid( 身份 证 号 ,7,4) In (1999, 2000) 
.Mid( 身份 证 号 ,7,4) Not In (1999, 2000) 
.Mid( 身份 证 号 ,7,4) =1999 Or =2000 
.Mid( 身份 证 号 ,7,4) =1999 Or Mid( 身份 证 号 ,7,4) =2000 
.Mid( 身份 证 号 ,7,4) =1999 And =2000 
G. Mid( 身份 证 号 ,7,4) =1999 And Mid( 身份 证 号 ,7,4) =2000 
21. 执行 Select * From YPRYB Where 姓名 ( ) 语 句 , 输 出 姓名 中 含 “ 丽 " 字 的 全 


器 回 品 中 中 > 


部 人 员 信 息 。 
A. Like '* 丽 *'  B. Like '% 丽 %'  C. Like '_ 丽 _ D.Like ' 丽 ' 
E. RLike '* 丽 *' F. RLike '% 丽 %' G. RLike '_ 丽 _ H.RLike ' 丽 ' 


22. 在 表 YPRYB 中 ,查询 姓名 为 空 的 记录 ,执行 Select * From YPRYB Where( ) 语 
句 。 
A. 姓名 =Null B. 姓名 < = > Null 
C. IsNull( 姓 名 ) D. 姓名 Is Null 
E. 姓名 Is Not Null 
23. 假设 学 历 的 表 结构 为 编码 Char(1) .名称 Char(3) ,记录 有 ('1',' 无 ' ) .('2',' 专 
科 ' ) ('3' ,' 本 科 ' ) ('4' "研究 生 ' ) ('5', "博士 ' )。 用 Select 身份 证 号 ,姓名 ,( ) 
As 学 历 名 From YPRYB 语句 能 将 最 后 学 历 转 换 成 学 历 名 。 
A. ELT( 最 后 学 历 ,' 无 ' ,专科 ' ,本 科 ' ,研究 生 ' , "博士 ' ) 
B. Case 最 后 学 历 When 2 Then ' 专 科 ' When 3 Then ' 本科 ' When 4 Then ' 研 究 
生 ' When 5 Then ' 博 十 ' Else ' 无 ' End 
C. Case When 最 后 学 历 =2 Then ' 专 科 ' When 最 后 学 历 =3 Then ' 本 科 ' When 
最 后 学 历 =4 Then' 人 研究 生 ' When 最 后 学 历 =5 Then ' 博 士 ' Else ' 无 ' End 
D. 最 后 学 历 m(' 专 科 ' ，' 本 科 ' ,' 研 究 生 ' ,博士 ,无 ' ) 
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E. Hf( 最 后 学 历 =2,' 专 科 ' ,了 f( 最 后 学 历 =3 ,本 科 ' ,If( 最 后 学 历 =4， 研究生 ， 
(最 后 学 历 =5,' 博 士 ' ,' 无 ' ) ) ) ) 

F. 最 后 学 历 RLike ' 专 科 | 本 科 | 研 究 生 | 博士 | 无 ' 

G. (Select 名 称 From 学 历 Where 编码 =YPRYB. 最 后 学 历 ) 

24. 用 Select 身份 证 号 ,岗位 编号 ,( 。””) As 成 绩 From GWCJB 语句 能 将 笔试 成 绩 
转换 成 优 ( 大 于 或 等 于 90) 、 良 (80 至 89) ,合格 (60 至 79) 和 不 合格 (小 于 60)。 

A. ELT( 笔试 成 绩 ,' 优 ' ,' 良 ',' 合 格 ',' 不 合格 ' ) 

B. Case 笔试 成 绩 When 90 Then ' 优 ' When 80 Then ' 良 ”When 60 Then ' 合 格 ' 
Else ' 不 合格 ' End 

C. Case When 笔试 成 绩 > = 90 Then ' 优 When 笔试 成 绩 > = 80 Then ' 良 ' 
When 笔试 成 绩 > =60 Then ' 合 格 ' Else ' 不 合格 ' End 

D. Hf( 笔试 成 绩 <60,' 不 合格 ' ,了 f( 笔试 成 绩 <80,' 合 格 ' ,If( 笔试 成 绩 <90,' 良 


Wr 
E. (笔试 成 绩 > =90， 优 ,If( 笔试 成 绩 > =80,' 良 ' ,If( 笔试 成 绩 > =60,' 合 
格 ' ,不 合格 ' ) ) ) 
25. 用 Select 语句 进行 两 个 表 连 接 时 ,用 ( 。” ”) 连 接 类 型 仅 输 出 符合 连接 条 件 的 记录 。 
A. Inner Join B. Right Join C. Left Join D. Natural Join 
E. Join 


26. 假设 在 YPRYB、GWCJB 中 都 没有 身份 证 号 和 岗位 编号 为 Null 的 记录 ,在 Select 
YPRYB. 身份 证 号 ,岗位 编号 ,姓名 ,笔试 成 绩 From 后 填 ( 中 ) ,语句 功能 相同 ; 填 
( @ ) ,语句 查询 结果 中 的 身份 证 号 或 岗位 编号 可 能 有 Null。 

. YPRYB,GWCJB On YPRYB. 身份 证 号 =GWCJB. 身份 证 号 

. YPRYB Natural Join GWCJB 

YPRYB Join GWCJB On YPRYB. 身份 证 号 =GWCJB. 身份 证 号 

.YPRYB Left Join GWCJB On YPRYB. 身份 证 号 =GWCJB. 身份 证 号 

.YPRYB Inner Join GWCJB On YPRYB. 身份 证 号 =GWCJB. 身份 证 号 

.YPRYB Right Join GWCJB On YPRYB. 身份 证 号 =GWCJB. 身份 证 号 
G. YPRYB Join GWCJB Where YPRYB. 身份 证 号 =GWCJB. 身份 证 号 
H. YPRYB ,GWCJB Where YPRYB. 身份 证 号 =GWCJB. 身份 证 号 

27. 假设 GWCJB 中 有 多 个 不 同 岗位 的 数据 ,选择 可 以 参与 子 查询 运算 的 符号 。 
Select * From GWCJB Where 面试 成 绩 (””) (Select AVG( 面试 成 绩 ) From GWCJB 
Group By 岗位 编号 ) ;去 掉 子 查询 语句 中 的 “Group By 岗位 编号 "短语 后 ,可 以 参与 子 查 询 
运算 的 符号 有 ( @ )。 

洲 . 训 B. In ,A | ) || 
E. <=Any F. =Some G. Not Exists 
28. 下 列 语句 中 ,( ) 可 以 执行 多 次 而 不 会 引发 系统 出 错 。 
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HONmp 


.Create Table 课程 (课程 号 Char(3 ) , 课程 名 VarChar(50) ) 

.Create Table If Not Exists 课程 (课程 号 Char(3), 课程 名 VarChar(50) ) 

.Create Or Replace View 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 

.Create View 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 

Create Table If Not Exists 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 
F.Create Table 岗位 As Select 岗位 编号 , 岗位 名 称 From GWB 

29. 建立 视图 时 ,视图 的 数据 源 可 以 为 ( )。 
A. 子 查 询 B. 数据 表 C. 另 一 个 视图 D. 数据 库 
下 ，Create 子 句 


、SQL 语句 填空 题 
1. 输出 申报 两 个 及 以 上 岗位 人 员 的 身份 证 号 .姓名 和 岗位 数 ,输出 结果 按 岗位 数 由 
多 到 少 排序 。 


Select 身份 证 号 ,姓名 ， 四 ”ms 岗位 数 From 
YERYB @ GoB 图 身份 证 号 
@ 岗位 数 习 Order By ® ; 
2. 删除 GWCJB 中 笔试 成 绩 是 所 报 岗 位 最 低 分 的 数据 记录 。 


Create ”QZDF Rs Select 岗位 编号 ， @_As 最 低 分 


站 局 中 双关 


From GWCJB ”岗位 编号 ; /* 创建 每 个 岗位 最 低 分 对 象 ZDF * / 
Delete From GWCJB Where @ = /*# 用 嵌 套 SQL 语句 删除 最 低 分 的 记录 * / 
(Select _@@ From ZDF Where GWCJB. 岗 位 编号 = ZDF. 岗 位 编号 ); 
Drop _@_ZDF; /* 删除 不 再 使 用 的 对 象 ZDF * / 


3. 统计 身份 证 号 219901199001011351 申报 的 岗位 情况 ,输出 内 容 包 括 岗 位 编号 、 岗 
位 名 称 、 人 数 和 申报 人 数 ,输出 结果 按 申 报 率 (申报 人 数 / 人 数 ) 由 高 到 低 排序 。 

Select 岗位 编号 ,岗位 名 称 , 人 数 ， 

(Select ”四 From GWCOB Where ©® ) 

AS 申报 人 数 

FROM GWB Where 岗位 编号 _ @ 

(Select ”四 From GWCJB Where 身份 证 号 =219901199001011351  ) 

@ 申报 人 数 /人 数 _@ ; 


五 、SQL 语句 输出 结果 填空 题 
依据 成 绩 和 课程 表 中 的 数据 ,填写 各 个 语句 的 运行 结果 。 
成 绩 课程 
学 号 课程 号 成 绩 课程 号 课程 名 
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22169901 12 站 课程 号 课程 名 
22169901 13 90 11 政治 

22169901 14 85 12 英语 

22169901 15 90 13 大 学 计算 机 
22169902 11 85 14 数据 库 及 程序 设计 
22169902 过 79 15 高 等 数学 
22169902 14 88 16 线性 代数 
24169910 12 50 

24169911 13 77 

24169911 14 66 








1. 执行 下 列 语句 输出 “中 “ 行 数 据 , 最 后 一 行 的 人 数 是 _@ _, 最 高 分 是 @ 。 
如 果 语 句 中 “课程 Natural Join 成 绩 "短语 改 为 “课程 Join 成 绩 On 课程 . 课程 号 = 成 绩 . 课 
程 号 ”, 则 输出 “四 “ 行 数据 。 
Select 课程 .课程 号 , 课程 名 ,Count (* ) Rs 人 数 ,Max (成 绩 ) Rs 最 高 分 
From 课程 Natural Join 成 绩 
Group By 课程 .课程 号 Order By 4 DESC; 


2. 执行 下 列 语句 输出 _Q@ _ 行 数据 ,最 后 一 行 的 人 数 是 _@ ,最 高 分 是 @ 。 
如 果 将 语句 中 的 “Count( * )” 改 为 *Count( 学 号 )" , 则 最 后 一 行 的 人 数 是 _@ ;如 果 再 
将 语句 中 的 Left 改 为 Right, 则 输出 _@_ 行 数据 ,最 后 一 行 的 人 数 是 _@ _, 最 高 分 


是 @@。 
Select 课程 .课程 号 , 课程 名 ,Count (* ) Rs 人 数 ,Max (成 绩 ) Rs 最 高 分 


From 课程 Left Join 成 绩 on 课程 .课程 号 城 绩 .课程 号 
Group By 课程 .课程 号 Order By 最 高 分 DESC; 


3. 执行 下 列 语句 输出 _Q@_ 行 数据 ,最 后 一 行 的 人 数 是 _@ ,平均 分 是 @ 。 
如 果 将 平均 分 的 子 查询 改 为 *IfNull( (Select AVG( 成 绩 ) From 成 绩 Where 课程 . 课程 号 = 
成 绩 .课程 号 ) ,0) ”, 则 最 后 一 行 的 平均 分 是 四 。 
Select 课程 号 , 课程 名 ， 
(Select Count (* ) From 成 绩 Where 课程 .课程 号 城 绩 . 课 程 号 ) Rs 人 数 ， 


(Select AVG (成 绩 ) From 成 绩 Where 课程 .课程 号 城 绩 .课程 号 ) Rs 平均 分 
From 课程 Group By 课程 号 Order By 平均 分 DESC; 


4. 执行 下 列 语句 后 ,课程 表 中 6 门 课程 的 平均 分 依次 是 四 、® 加 、@ 
@ .©® 和 © 
Alter Table 课程 AGd 平均 分 Int; 


Upadate 课程 Set 平均 分 = 
(Select AVG (成 绩 ) From 成 绩 Where 课程 .课程 号 城 绩 .课程 号 ) ; 
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六 、SQL 语句 设计 题 


1. 在 GWCJB 中 增加 一 个 字段 一 一 岗位 平均 笔试 分 ( Int) ,将 对 应 岗位 的 笔试 平均 分 
填 人 该 字段 。 

2. 输出 GWB 中 每 个 岗位 编号 岗位 名 称 、 人 数 .申报 人 数 和 笔试 最 高 分 ( 没 人 申报 为 
0)。 

3. 将 GWCJB 中 笔试 成 绩 和 面试 成 绩 分 成 两 个 记录 , 按 岗 位 编号 和 身份 证 号 排序 存 
储 到 表 BSMS 中 ,包含 的 字段 有 岗位 编号 .身份 证 号 .考试 形式 和 成 绩 4 个 字段 ,考试 形式 

4. 利用 视图 ,输出 高 于 个 人 笔试 平均 分 的 岗位 和 个 人 所 获 笔试 最 高 分 的 岗位 。 两 个 
输出 结果 都 包括 身份 证 号 .姓名 ,岗位 名 称 和 笔试 成 绩 。 


1. SQL 分 哪些 子 语言 ? 各 个 子 语言 的 功能 是 什么 ? 各 由 哪些 语句 构成 ? 

2. 通常 说 表达 式 X In (XX[ ,和 XX，…,X,]) 可 以 转换 成 =Xi[ Or X=X, Or … Or 
X=X] 或 X Between X， And X ,在 什么 条 件 下 可 以 相互 转换 ? 在 什么 情况 下 使 用 In、Or 
或 Between 更 方便 ? 

3. Insert 和 Replace 都 能 向 表 中 增加 记录 ,这 两 个 命令 各 自 的 特点 有 哪些 ? 

4. 表 之 间 的 自然 连接 和 内 连接 几乎 具有 相同 的 功能 ,自然 连接 对 表 结 构 有 什么 要 
求 ? 自然 连接 与 内 连接 各 有 什么 特点 ? 二 者 的 主要 差异 有 哪些 ? 

5. 通过 左右 连接 和 查询 语句 租 套 均 可 以 查询 出 没有 人 申报 的 岗位 情况 ,如 例 4. 49 
和 例 4.50, 二 者 的 主要 差异 有 哪些 ? 

6. SQL 语句 主要 对 表 进 行 操作 ,通过 哪些 方式 可 以 在 一 条 SQL 语句 中 对 多 个 表 进 行 
操作 ? 这 些 方式 各 有 哪些 特点 ? 

7. 恰当 地 设计 和 运用 视图 ,可 以 蔡 代 栓 套 的 SQL 语句 解决 比较 复杂 的 问题 ,视图 与 
符 套 各 有 哪些 特点 ? 如 何 通 过 视图 对 象 解决 较 复杂 的 嵌 套 问题 ? 通常 府 套 语句 和 视图 对 
象 各 适合 解决 什么 类 型 的 问题 ? 


第 4 章 ， 数据库 访问 及 结构 化 查询 语言 


(69 


小 
un 
埃 


MySQL 程序 设计 


MySQL 5.0 版 本 支持 过 程式 数据 库 对 象 ,包括 触发 器 .事件 .存储 过 程 和 存储 函数 等 
内 容 。 所 谓 过 程式 数据 库 对 象 就 是 将 一 组 MySQL 语句 作为 一 个 对 象 存储 于 数据 库 中 , 系 
统 通过 特定 的 触发 条 件 或 客户 端 调用 即 可 执行 这 组 MySQL 语句 ,从 而 有 效 地 提高 数据 库 
的 处 理 速度 和 数据 库 编程 的 灵活 性 ,增强 数据 库 的 安全 性 。 

MySQL 程序 设计 即 创建 .管理 和 应 用 这 些 过 程式 数据 库 对 象 , 主 要 包括 下 列 问题 

(1) MySQL 语句 有 哪些 语法 元 素 ” 如 何 定义 变量 ”如 何 为 变量 赋值 y” MySQL 语句 
中 有 哪些 流程 控制 语句 ? 

(2) 触发 器 的 用 途 是 什么 ”如 何 定义 .修改 及 删除 触发 器 ? 

(3) 事件 是 如 何 发 生 的 ? 如何 定 义 事件 ”事件 与 触发 器 有 哪些 不 同 ? 

(4) 什么 是 存储 过 程 ?” 什么 是 存储 函数 ?两 者 之 间 有 哪些 不 同 ? 


5.1 过 程式 数据 库 对 象 应 用 实例 


存储 过 程 和 存储 函数 是 MySQL 数据 库 中 一 些 有 序 的 SQL 语句 集合 ,通过 调用 存储 过 
程 和 存储 函数 执行 SQL 语句 ,可 以 避免 重复 编写 SQL 语句 。 存 储 过 程 和 存储 函数 在 
MySQL 服务 器 端 存储 和 执行 ,可 以 减少 客户 端 和 服务 器 端的 数据 传输 。 

1. 存储 过 程 的 设计 过 程 

【 例 5.1】 设计 一 个 过 程 休 , 如果 参数 值 长 度 为 5 位 , 则 输出 对 应 岗位 号 的 申报 人 
数 .笔试 最 高 分 ;如 果 参 数值 长 度 为 18 位 , 则 输出 对 应 人 员 的 申报 岗位 数 和 笔试 最 高 分 。 

(1) 启动 MySQL 客户 端 : 在 XAMPP 控制 面板 中 单 击 Shell 选项 , 在 XAMPP For 
Windows 窗口 中 输入 如 下 命令 ,登录 MySQL 数据 库 服务 器 : 


Mysql uywy 卫 


输入 用 户 ywy 的 密码 ywy211 后 按 Enter 键 ,进入 MySQL 客户 端 。 
(2) 创建 存储 过 程 : 在 提示 符 “mysql > "下 输入 如 下 命令 打开 RCZP 数据 库 : 


Use RCZP; /* 打开 RCZP 数 据 库 * / 





(3) 依次 输入 如 下 语句 ,创建 存储 过 程 休 : 


Delimiter 拓 /* 创建 过 程 结束 符号 * / 
Create Procedure TJ (In CS VarChar (18)) 
Begin /* 外 层 复合 语句 开始 * / 

Declare ZGF Int Default 0; /* 外 层 局 部 变量 ZGF * / 

Set &QST =Cs; /* 将 参数 cs 的 值 赋 给 全 局 变量 @ST * / 

If Char Length (@ ST) 5 Then 

Begin /* 内 层 复合 语句 开始 * / 
Declare RS Int; /* 内 层 局 部 变量 RS * / 


Select Count (身份 证 号 ) ,Max (笔试 成 绩 ) Into RS, ZGF /* 为 外 层 局 部 变量 ZGF 赋值 * / 
From RCZP.GWCJB where 岗位 编号 <@ ST; 
Set @ST =Concat ("岗位 号 : ",@ST,", 人数: ",RS); /* 引用 并 为 全 局 变量 @ ST 赋值 * / 


End; /* 内 层 复合 语句 结束 * / 
ElseIf Char Length (@ ST) 48 Then 

Begin /* 内 层 复合 语句 开始 * / 

Declare WS Int; /*# 内 层 局 部 变量 GRS * / 


Select Count (岗位 编号 ), Max (笔试 成 绩 ) Into GWS, ZGF 
/* 为 外 层 局 部 变量 ZGF 赋值 * / 
From RCZP .GWCJB where 身份 证 号 <@ ST; 
Set @ ST =Concat ("身份 证 号 :",@ST, ", 岗 位 数 : ",GRS) 7 


End; /*# 内 层 复合 语句 结束 * / 
End If; 
Set @ ST =Concat (@ ST, ", 最 高 分 : ",2GF); 
Select @ ST; 
End; /* 外 层 复合 语句 结束 * / 
排 /*# 创建 过 程 结束 * / 
Delimiter ; /* 恢复 MysQL 语 句 结 束 符号 为 *;”* / 


2. 存储 过 程 的 调用 

调用 存储 过 程 休 J, 查看 结果 : 在 MySQL 客户 端 分 别 输 入 如 下 语句 ,执行 结果 如 
图 5-1 所 示 。 

Call TJ ("229901199503121538"); /* 调用 存储 过 程 TJ, 参 数 为 身份 证 号 * / 

Call TJ("A0001"); /* 调用 存储 过 程 TJ, 参 数 为 岗位 编号 * / 

3. 存储 过 程 中 的 注释 


在 存储 过 程 休 中 ,/ * 和 */ 之 间 的 内 容 为 注释 ,注释 不 影响 程序 的 执行 ,用 于 帮助 人 
们 阅读 和 理解 程序 。 在 MySQL 中 有 如 下 3 种 格式 的 注释 : 

(1) # 注释 : 为 行 尾 注释 ,书写 在 语句 之 后 ,注释 内 容 到 本 行 结束 ,如 : 

Use RCZP; 打开 数据 库 RCZP 

(2) -- 注 释 : 连续 两 个 减 号 “--" 构 成 的 行 尾 注释 ,注释 内 容 到 本 行 结束 ,如 : 
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call tjC"A0001"); 
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图 5-1 存储 过 程 TJ 的 执行 结果 


Select * from gwb; -- 浏 览 gwb 表 中 全 部 数据 
(3) /* *#/ 注 释 ; 可 以 放 在 语句 中 的 任何 位 置 , /* 和 * /之 间 可 以 包含 多 行 注 释 内 
容 , 如 : 


Use RCZP /* 打开 RCZzP 数据库 * / 
Call /* 调用 存储 过 程 使 用 Call 语句 * / TJ("A0002"); 
Call /* 调用 存储 过 程 TJ, 当 使 用 身份 证 号 作为 参数 时 





函数 返回 的 是 对 应 人 员 所 申报 的 岗位 数 及 最 高 分 * / 


TJ("229901199503121538"); 


5.2 常用 MySQL 基本 语句 


设计 过 程式 数据 库 对 象 需要 编写 程序 ,程序 由 多 条 MySQL 语句 组 成 ,包括 声明 变量 、 
节 量 赋值 分支、 循环 和 提取 表 中 数据 等 语句 


变 


5.2.1 复合 语句 


当 过 程式 数据 库 对 象 的 处 理 代码 只 有 一 条 语句 时 ,可 以 直接 书写 MySQL 语句 。 当 多 
条 MySQL 语句 构成 过 程 体 时 ,必须 用 复合 语句 进行 书写 。 所 谓 复合 语句 ,就 是 由 Begin 
开始 ,End 结束 ,之 间 多 条 MySQL 语句 构成 的 语句 组 (也 称 复合 语句 体 )。 复 合 语句 是 一 
个 独立 的 程序 段 , 复 合 语句 体内 还 可 以 租 套 男 一 个 复合 语句 ,也 称 内 层 复合 语句 。 





5.2.2 MYSQL 变量 及 其 赋值 


变量 用 于 在 过 程式 数据 库 对 象 中 临时 存放 数据 ,并 且 存 放 的 数据 可 以 随 着 程序 的 运 
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行 而 随时 改变 。 
1. 局 部 变量 


仅 在 复合 语句 及 内 层 复合 语句 中 可 以 访问 (引用 和 存储 其 值 ) 的 变量 称 为 该 复合 语 
句 的 局 部 变量 ,主要 用 于 存储 复合 语句 体 中 的 临时 数据 。 一 个 复合 语句 中 可 以 访问 自身 
及 外 层 复 合 语句 中 声明 的 局 部 变量 ,但 外 层 复 合 语句 不 能 访问 内 层 声 明 的 局 部 变量 。 

语句 格式 : 

Declare < 变量 名 1 >[, 变 量 名 2[,…… ]] < 数据 类 型 >[Default < 表达 式 习 


局 部 变量 只 能 在 复合 语句 体 中 声明 ，Declare 语句 必须 写 在 Begin 之 后 ,其 他 语句 之 
前 ,可 以 有 多 条 Declare 语句 ,语句 中 相关 项 的 含义 如 下 : 

(1) < 变量 名 n > : 用 于 标识 变量 ,如 gsmc ,变量 名 可 以 用 字母 ,数字 、 下 面 线 (_) 和 
$ 字符 组 成 ,英文 字母 不 区 分 大 小 写 , 但 不 允许 与 系统 函数 或 语句 中 的 关键 字 同 名 。 

(2) < 数据 类 型 > : 指定 变量 中 存放 数据 的 类 型 。 

(3) Default < 表达 式 > : 用 于 指定 变量 的 默认 值 。 默 认 值 的 数据 类 型 与 变量 声明 
的 数据 类 型 必须 一 致 。 若 省 略 Default 字句 , 则 默认 值 为 NULL。 

【 例 5.2】 在 过 程 体 中 声明 局 部 变量 。 


Declare gwbh,gwmc char; /* 声明 局 部 变量 gwbh 和 gwmc, 其 类 型 均 为 字符 型 * / 
Declare rs int Default 0; /* 声明 局 部 变量 rs, 其 类 型 为 int, 默 认 值 为 0 * / 
2. 全 局 变量 


全 局 变量 是 指 在 一 个 过 程式 数据 库 对 象 中 定义 ( 赋值 ) 的 变量 ,在 其 他 过 程式 数据 库 
对 象 中 均 可 访问 的 变量 。 全 局 变量 名 由 @ 符号 开始 ,不 需要 声明 其 数据 类 型 ,所 存储 值 的 
数据 类 型 由 变量 赋值 时 的 数据 类 型 决定 ,如 @ ST。 

利用 全 局 变量 可 以 实现 在 多 个 过 程式 数据 库 对 象 之 间 进 行 数据 传递 。 例 如 ,在 执行 Call 
了 ("A0001" ) 语 句 后 ,还 可 以 执行 Select @ ST 语句 ,输出 过 程 TJ 中 赋值 的 全 局 变量 @ ST。 


3. 变量 赋值 

在 过 程 体 中 ,可 以 使 用 Set 语句 为 变量 赋值 , 即 ,存储 或 修改 变量 的 值 。 

语句 格式 : 

Set 变量 名 1 上 表达 式 1 [, 变 量 名 2 表达 式 2 [,……] ] 

语句 的 功能 是 将 表达 式 的 值 存储 到 对 应 的 变量 中 ,变量 名 可 以 是 全 局 变量 或 局 部 


变量 。 
【 例 5.3】 在 过 程 体 中 为 变量 赋值 。 
Set gwbh "A0001" ,gwmc ~" 行 长 助理 ",rs -0; /* 为 局 部 变量 gwbh .gwnc 和 rs 赋值 * / 
Set @bmrs -0; /* 定义 全 局 变量 ebmrs 并 为 其 赋值 * / 
Select gwbh, gwmc, rs, @ bmrs; /* 输出 定义 的 变量 值 * / 
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5.2.3 获取 一 行 查询 结果 


在 MySQL 过 程式 对 象 的 过 程 体 中 ,执行 Select…Into 语句 可 以 获取 一 行 数据 查询 
结果 。 

语句 格式 : 

Select < 表达 式 表 >Into < 变量 名 表 汪 rom < 表 名 >[Where < 条 件 习 


变量 名 表 中 的 变量 个 数 与 表达 式 个 数 应 该 相等 , 且 按 顺序 一 一 对 应 。 此 语句 将 查询 
各 列 结果 分 别 保存 到 对 应 的 变量 中 。 此 语句 返回 的 结果 只 能 有 一 行 数据 。 

【 例 5.4】 在 过 程 体 中 将 GWB 表 中 岗位 编号 A0001 要 求 的 最 低 学 历 和 人 数 保存 到 
局 部 变量 zdxl 和 rs 中 。 


Declare zdx] Char (1); 
Declare rs Int; 
Select 最 低 学 历 , 人 数 Into zdxl1, rs From RCZP.GWB where 岗位 编号 "A0001"; 


5.2.4 获取 多 行 查询 结果 


要 获取 多 行 数据 ,在 存储 过 程 或 函数 中 可 以 定义 游标 ,游标 是 由 一 条 Select 语句 检索 
或 统计 出 来 的 记录 集 , 在 一 个 存储 过 程 或 存储 函数 中 可 以 定义 多 个 游标 ,只 要 每 个 游标 的 
名 字 不 同 即 可 。 

游标 的 应 用 可 以 分 成 如 下 几 个 步骤 。 


1. 声明 游标 

在 使 用 游标 前 需要 先 声明 ,声明 游标 的 语句 必须 书写 在 过 程 体 中 局 部 变量 声明 部 分 。 

语句 格式 : 

Declare < 游标 名 称 > Cursor For <Select 语 句 > 

游标 名 称 的 命名 规则 与 表 名 相同 ,另外 ,声明 游标 的 Select 语句 不 能 含有 into 短语 。 

2. 打开 游标 

声明 游标 后 即 可 打开 游标 ,打开 游标 实际 上 就 是 执行 游标 中 的 Select 语句 ,并 将 语句 
检索 到 的 记录 集 与 游标 名 称 进 行 绑 定 。 

语句 格式 : 

Open < 洲 标 名 称 > 

3. 读 取 游 标 中 的 数据 

在 MySQL 中 ,使 用 Fetch…Into 语句 读 取 游标 中 的 各 行 数据 。 
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语句 格式 : 

Fetch < 游标 名 称 >Into < 变量 名 1 >[, < 变量 名 2 >…] 

Fetch…Into 语句 将 游标 当前 指向 的 一 行 数据 赋值 给 into 短语 中 的 变量 ,变量 个 数 应 
该 与 定义 游标 时 Select 表达 式 个 数 一 致 。 

若 要 获取 游标 中 的 多 行 数 据 , 可 以 使 用 循环 结构 逐 行 读 取 。 

4. 关闭 游标 

游标 使 用 结束 后 ,必须 关闭 游标 。 

语句 格式 : 

Close < 游标 名 称 > 

关闭 游标 后 ,不 能 再 执行 Fetch 语句 读 游标 ,除非 再 运行 Open 语句 打开 游标 。 


5.3 ”MySQL 分 支 结 构 程序 设计 


分 支 结 构 根 据 条 件 判断 结果 选择 执行 某 组 语句 ,也 称 条 件 结构 或 条 件 判断 结构 。 在 
MySQL 程序 设计 中 ,条 件 结构 有 下 和 Case 两 种 。 


5.3.1 下 分 支 结构 程序 设计 


If 结构 语句 用 于 实现 一 个 基本 的 条 件 结构 。 
语句 格式 : 


If 条 件 1 Then 语句 组 1 
[ElseIf 条 件 2 Then 语句 组 2 ] 


LElseIf 条 件 n Then 语句 组 n ] 
[Else 语句 组 n 刀 ] 
End If; 
执行 ff 语句 时 ,流程 如 图 5-2 所 示 , 从 第 一 个 条 件 
开始 判断 , 当 某 个 条 件 i 为 True( 真 ) 时 , 则 执行 语句 组 


i, 随 后 执行 对 应 的 End 下 后 面 的 语句 ;车 所 有 条 件 都 ”po ; 
为 False( 假 ) , 则 执行 Else 后 的 语句 组 n+1; 当 所 有 条 > Te 。「 语 向 组 
False 





语句 组 1 








语句 组 2 























件 均 为 False 且 没有 Else 语句 时 ,程序 直接 执行 对 应 

















的 End 于 后 面 的 语句 。 语句 组 n+1 
下 语句 结构 使 用 End If 作为 结束 标识 ,两 者 必须 
配对 使 用 。 a 
【 例 5.5】 输出 岗位 编号 A0001 的 最 高 笔试 成 绩 图 52 HF…Else 流程 图 
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的 等 级 。 
Begin 
Declare cj] Int; 
Declare tdqcj Cursor For Select 笔试 成 绩 From GWCJB 


Where 岗位 编号 2"A0001" Order By 笔试 成 绩 DESC ; /** 定义 游标 tqcj * / 
Open tqcj; /* 打开 游标 tqcj * / 
Fetch tqcj Into cj; /* 读 取 游标 中 第 1 行 数据 并 保存 在 变量 cj 中 * / 
Close tqcj; /* 关闭 游标 tqcj * / 


If cj >=85 Then Set @djcj =>" 优秀 "; ” /* 证 语句 实现 数据 转换 * / 
Elseif cj >30 Then Set @qdjcj 一 良好 "7 
Elseif cj >=60 Then Set @ djcj "及 格 "; 
Else Set edjcj = 不 合格 "7 
End if; 
Select cj, @djcj; /* 显示 结果 * / 
End 


5.3.2 ”Case 分支 结构 程序 设计 


Case 语句 结构 适用 于 多 分 支 条 件 的 处 理 。 
语句 结构 1 : 
Case 表达 式 

When 值 1 Then 语句 组 1 

[when 值 2 Then 语句 组 2] 








语句 组 1 











[when 值 n Then 语句 组 n] 
[Else 语句 组 n 世 ] 
End Case; 
执行 Case 语句 时 ,流程 如 图 5-3 所 示 ,如 果 某 个 
值 i 与 表达 式 相 等 , 则 执行 语句 组 i, 随后 执行 对 应 的 
End Case 后 面 的 语句 。 如 果 所 有 的 值 i(i =1,…,n) 
与 表达 式 的 值 均 不 相等 , 则 执行 Else 之 后 的 语句 组 n 
+1, 若 无 Else 子 句 , 则 执行 对 应 的 End Case 后 面 的 图 53 ”Case 语句 控制 流程 
语句 。 
【 例 5.6】 输出 gwb 表 中 岗位 编号 A0001 的 最 低 学 历 要 求 及 说 明 。 
Begin 
Declare xl char(1); 
Declare tqxl Cursor For Select 最 低 学 历 From GRB 





























Where 岗位 编号 =2"A0001" ; /* 定义 游标 tqxl * / 
Open tqx]; /* 打开 游标 tqxl * / 
Fetch tqxl Into xl1; /* 读 取 游标 中 的 第 1 行 数据 并 保存 在 变量 x1 中 * / 
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Close tqxl; /* 关闭 游标 taxl * / 

Case x1 /* case 语 句 实 现 数据 转换 * / 
When "1" Then Set @ zdxlsm 一 "无 要 求 "; 
When "2" Then Set @ zdxlsm 一 "专科 "; 
When "3" Then Set @ zdxlsm 一 "本科 "; 
When "4" Then Set @ zdxlsm 一 "研究 生 "; 
When "5" Then Set @ zdxlsm 一 "博士 "; 

End Case; 

Select xl, @zdxlsm; /* 显示 结果 * / 

End 


语句 结构 2: 


Case 
When 条 件 1 Then 语句 组 1 
[When 条 件 2 Then 语句 组 2] 
i 条 件 n Then 语句 组 n] 
[Else ”语句 组 n 忆 ] 
End Case; 
程序 执行 流程 与 图 5-3 类 似 ,差别 仅 在 于 将 图 中 的 “表达 式 = 值 " 换 为 “条 件 i”"。 如 
果 某 个 条 件 i 的 值 为 True , 则 执行 语句 组 i, 随 后 执行 对 应 的 End Case 后 面 的 语句 。 若 所 
有 条 件 值 均 为 False, 则 执行 Else 之 后 的 语句 组 上 +1, 若 无 Else 子 句 , 则 执行 对 应 的 End 


Case 后 面 的 语句 。 
【 例 5.7】 用 Case 语句 格式 2 输出 岗位 编号 A0001 的 最 高 笔试 成 绩 的 等 级 。 


Begin 
Declare cj Int; 
Declare tdqcj Cursor For Select 笔试 成 绩 From GWCJB 


Where 岗位 编号 2'A0001" Order By 笔试 成 绩 DESC ; * 定义 游标 tgqcj * / 
Open tqcj; /* 打开 游标 tqcj * / 
Fetch tqcj Into cj; /* 读 取 游 标 中 的 第 1 行 数据 并 保存 在 变量 cj 中 * / 
Close tqgcj; /* 关闭 游标 tqcj * / 
Case /* case 语 句 实现 数据 转换 * / 


When cj >-85 Then Set @ djcj 二 优秀 "; 
When cj >370 Then Set @qdjcj = 良好"; 
When cj >=60 Then Set @qdjcj "及 格 "; 
Else Set @djcj 二 不 合格 "; 
End case; 
Select cj, @djcj; /* 显示 结果 * / 
End 


5.4 MySQL 循环 结构 程序 设计 


循环 结构 是 指 有 条 件 地 重复 执行 某 个 程序 段 , 重 复 执 行 的 程序 代码 段 被 称 为 循环 体 。 
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根据 判断 循环 条 件 和 执行 循环 体 的 先后 顺序 ,有 当 型 和 直到 型 两 种 循环 结构 。MySQL 有 
While .Repeat 和 Loop 三 种 循环 语句 。 


5.4.1 While 循环 结构 


语句 结构 : 
[ 赁 环 名 >:] While < 储 环 条 件 >Do 
< 语句 组 > 
End While [ < 循环 名 习 
While 语句 结构 属于 当 型 循环 ,可 以 为 循环 语句 结构 命名 。 若 定义 循环 名 , 则 与 对 应 
的 End While < 循环 名 > 必须 相同 。 语 句 组 即 循环 (FB 





























体 ,是 重复 执行 的 程序 代码 。 

执行 While 语句 时 ,如 图 54 所 示 , 首先 判断 循 False 
环 条 件 , 若 为 True, 则 执行 语句 组 ,随后 再 判断 循环 条 循环 条 件 
件 站 如 循 环 条 件 仍 然 为 True 则 再 次 执 行 语 句 组 9 执行 Iterate Truel 执行 Leave 
,直至 循环 条 件 为 False 才 结 束 循环 结构 ,执行 对 名 浊 
应 的 End While 后 面 的 语句 。 

若 首次 判断 循环 条 件 即 为 False, 则 语句 组 一 次 
都 不 执行 。 


在 执行 循环 体 (语句 组 ) 的 过 程 中 , 如果 执 行 到 图 54 当 型 循环 控制 流程 
lterate 语句 , 则 转 到 While < 循环 条 件 > 语句 判断 循 
环 条 件 ;如 果 执 行 到 Leave 语句 , 则 提前 结束 循环 结构 ,执行 循环 结构 后 面 的 语句 。 
语句 格式 : 


Leave < 循环 名 >; 
Iterate < 循环 名 >; 


Leave 和 Iterate 语句 通常 用 在 循环 体内 的 分 支 结构 中 , 以便 有 选择 地 执行 这 两 条 
语句 。 
【 例 5.8】 在 MySQL 的 过 程 体 中 ,统计 gwb 表 中 要 求 的 各 学 历 招聘 人 员 的 总 数 。 
Begin 
Declare rs, rsl,rs2,rs3,rs4,rs5 int; /* 定义 局 部 变量 ,int 数据 类 型 * / 
Declare zdx] char; /* 定义 局 部 变量 zdxl, char 数据 类 型 * / 
Declare done Boolean Default True; ”/* 声明 局 部 变量 done, boolean 类 型 ,默认 值 
True * / 
Declare rstj Cursor For Select 最 低 学 历 , 人 数 From gwb; /* 定义 游标 rstj * / 
Declare Continue Handler For Not Found Set done False; /* 定义 Continue 句 柄 * / 
Set rsl -0,rs2 -0,rs3 -0,rs4 -0,rs5 -0;/* 变量 赋 初 值 * / 
Open rstj; /* 打开 游标 rstj * / 
Fetch rstj Into zdxl,rs; /* 读 游标 中 第 1 行 数据 并 保存 在 zdxl 和 rs 变量 中 * / 
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While done do /* 若 成 功 读 取 游标 中 的 数据 , 则 进入 循环 * / 
Case zdxl /* case 语 句 , 表 达 式 为 最 低 学 历 码 * / 
When "1" Then Set rsl =rsl +rs; ”/* 最 低 学 历 为 1, 则 变量 rsl 加 1, 下 同 * / 
When "2" Then Set rs2 =rs2 +rs; 
When "3" Then Set rs3 =rs3 +rs; 
When "4" Then Set rs4 =rs4 +rs; 
When "5" Then Set rs5 =rs5 +rs; 


End Case ; 
Fetch rstj Into zdxl,rs; /* 读 取 游标 rstj 中 的 下 一 行 数 据 * / 
End while; 
Select rsl, rs2, rs3, rs4, rs5; /* 显示 结果 * / 
Close rstj; /* 关闭 游标 * / 
End 


使 用 循环 结构 逐 行 读 取 游标 ( Fetch 语句 ) 中 的 数据 时 ,通常 声明 1 个 逻辑 型 变量 控 
制 循环 (如 例 5.8 中 的 done) ,再 声明 Continue 句柄 ,将 循环 控制 变量 与 游标 关联 起 来 。 
语句 格式 : 


Declare Continue Handler For Not Found MySQL 子 句 ; 


游标 中 没有 可 读 的 数据 行 , 即 Not Found ,再 执行 Fetch 语句 将 执行 (触发 ) 该 语句 中 
的 MySQL 子 句 ,以 便 调整 循环 控制 变量 的 值 ,控制 循环 结构 的 走向 。 
【 例 5.9】 统计 招聘 2 人 以 上 ( 含 2 人 ) 的 岗位 ,输出 各 学 历 的 招聘 总 人 数 。 


Begin 
Declare rs,rsl,rs2,rs3,rs4,rs5 int; /* 定义 局 部 变量 rs, 其 为 int 类 型 * / 
Declare zdxl char; /* 定义 局 部 变量 zdxl1, 其 为 char 类 型 * / 


Declare done Boolean default true; ” ”/* 声明 boolean 型 局 部 变量 done, 默 认 值 true * / 
Declare rstj Cursor For select 最 低 学 历 , 人数 from gwb; /* 定义 游标 rstj * / 


Declare Continue Handler For Not Found Set done =false; /* 定义 Continue 句柄 * / 
Set rsl -0,rs2 -0,rs3 -0,rs4 -0,rs5-0; /* 变量 置 初 值 * / 
Open rstj; /* 打开 游标 rstj * / 
Fetch rstj Into zdxl,rs; /* 读 取 游标 中 的 第 1 行 数据 并 保存 在 zdxl 和 rs 变量 中 * / 
tj: While done do /* 若 成 功 读 取 游标 中 的 数据 * / 
If rs 人 Then /* 若 招聘 人 数 少 于 2 人 , 则 不 计数 , 读 取 游 标 下 一 行 ,继续 判断 循环 * / 
Fetch rstj Into zdx], rs; /* 读 取 游标 rstj 中 的 下 一 行 数据 * / 
Iterate tj; 
End If; 
Case zdxl /* case 语 句 判断 最 低 学 历 * / 


When "1" Then Set rsl =rs] +rs7 /* 最 低 学 历 为 1, 则 变量 rsl 加 1, 下 同 * / 
When "2" Then Set rs2 =rs2 +rs7 

When "3" Then Set rs3 =rs3 +rs7 

When "4" Then Set rs4 =rs4 +rs; 

When "5" Then Set rs5 =rs5 +rs; 

End Case; 
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Fetch rstj Into zdxl,rs; /* 读 取 游 标 rstj 中 的 下 一 行 数据 * / 
End while tj; 
Select rsl, rs2, rs3, rs4, rs5; /* 显示 结果 * / 
End 


(FH 始 ) 


语句 组 


5.4.2 ”Repeat 循环 结构 


语句 结构 : 
[ < 循环 名 >: ]Repeat 
< 语句 组 > 
Until < 多 环 条 件 > 
End Repeat [ < 循环 名 习 
Repeat 语句 是 直到 型 循环 ,执行 流程 如 
图 5-5 所 示 。 首 先 执行 语句 组 ,之 后 判断 循环 
条 件 , 若 循环 条 件 为 True, 则 结束 循环 结构 ,否则 ,再 次 执行 语句 组 ,进行 下 一 次 循环 。 
【 例 5.10】 用 Repeat 语句 统计 gwb 表 中 要 求 的 各 学 历 招 聘 人 员 的 总 数 。 





执行 Iterate 执行 Leave 























图 5-5 直到 型 循环 流程 


Begin 
Declare rs,rsl,rs2,rs3,rs4,rs5 int;  /* 定义 局 部 变量 rs, 其 为 int 类 型 * / 
Declare zdx] char; /* 定义 局 部 变量 zdx1, 其 为 char 类 型 * / 
Declare done Boolean default true; /* 声明 boolean 型 局 部 变量 done, 默认 值 
true */ 
Declare rstj Cursor For select 最 低 学 历 , 人 数 from gwb; /* 定义 游标 rstj * / 
Declare Continue Handler For Not Found Set done =false; /* 定义 Continue 句柄 * / 
Set rsl -0,rs2 -0,rs3 -0,rs4 -0,rs5-0; /* 变量 置 初 值 * / 
Open rstj; /* 打开 游标 rstj * / 
Fetch rstj Into zdxl,rs; /* 读 取 游 标 中 第 1 行 数据 并 保存 在 zdxl 和 rs 变量 中 * / 
Repeat 
Case zdxl /* case 语 句 判断 最 低 学 历 * / 
When "1" Then Set rsl =rsl +rs; ”/* 最 低 学 历 为 1, 则 变量 rsl 加 1, 下 同 * / 
When "2" Then Set rs2 =rs2 +rs; 
When "3" Then Set rs3 =rs3 +rs; 
When "4" Then Set rs4 =rs4 +rs; 
When "5" Then Set rs5 =rs5 +rs7 
End Case; 
Fetch rstj Into zdxl,rs; /* 读 取 游标 rstj 中 的 下 一 行 数据 * / 
Until Not done 
End Repeat; 
Select rsl, rs2, rs3, rs4, rs5; /* 显示 结果 * / 
Close rstj; /* 关闭 游标 * / 
End 
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5.4.3 loop 循环 结构 
































[ < 特 环 名 >: ]Loop 
< 和 语句 组 > 执行 Iterate 一 执行 Leave 
End Loop [ < 储 环 名 习 四 语句 组 
Loop 语句 属于 直到 型 循环 ,如 图 5-6 所 示 ， 
用 于 重复 执行 语句 组 ,没有 控制 条 件 ,所 以 


Loop 语句 自身 构成 无 限 循环 , 即 所 谓 死 循环 。 
通常 Loop 语句 组 中 用 Leave 语句 结束 循环 。 
【 例 5.11】 用 loop 语句 统计 gwb 表 中 要 求 的 各 学 历 招 聘 人 员 的 总 数 。 


图 5-6 ”Loop 循环 控制 流程 


Begin 
Declare rs,rsl,rs2,rs3,rs4,rs5 int;  /* 定义 局 部 变量 rs, 其 为 int 类 型 * / 
Declare zdx] char; /* 定义 局 部 变量 zdx1, 其 为 char 类 型 * / 
Declare done Boolean default true; 。 /* 声明 boolean 型 局 部 变量 done, 默 认 值 true * / 
Declare rstj Cursor For select 最 低 学 历 , 人 数 from gwb; /* 定义 游标 rstj * / 
Declare Continue Handler For Not Found Set done -false; /* 定义 Continue 句柄 * / 
Set rsl -0,rs2 -0,rs3 -0,rs4-0,rs5-0; /* 变量 置 初 值 * / 
Open rstj; /* 打开 游标 rstj * / 
Fetch rstj Into zdx], rs; /* 读 取 游标 中 第 1 行 数据 并 保存 在 zdxl 和 rs 变量 中 * / 
tj:Loop 
Case zdxl /* case 语 句 判断 最 低 学 历 * / 
When "1" Then Set rsl =rsl +rs; /* 最 低 学 历 为 1, 则 变量 rsl 加 1, 下 同 * / 


When "2" Then Set rs2 =rs2 +rs; 
When "3" Then Set rs3 =rs3 +rs; 
When "4" Then Set rs4 =rs4 +rs; 
When "5" Then Set rs5 =rs5 +rs; 


End Case; 
Fetch rstj Into zdxl, rs; /* 读 取 游标 rstj 中 的 下 一 行 数据 * / 
If not done Then Leave tj; /* 车 游标 rstj 中 的 数据 全 部 读 取 完 毕 , 则 退出 循环 * / 
End If; 
End Loop tj; 
Select rsl, rs2, rs3,rs4, rs5; /* 显示 结果 * / 
End 


5.5 存储 过 程 设计 


存储 过 程 是 一 组 为 实现 某 特定 功能 的 有 序 MySQL 语句 的 集合 ,实质 是 存放 于 数据 库 
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的 程序 对 象 ,用 户 通 过 存储 过 程 名 和 参数 即 可 调用 存储 过 程 。 存 储 过 程 具有 执行 效率 高 、 
减少 网 络 数据 流量 、 确 保 数据 库 安全 性 及 完整 性 等 优点 。 通 过 MySQL 语句 和 
PHPMyAdmin 可 视 化 数据 库 管 理 平台 均 可 以 创建 和 调用 存储 过 程 。 


5.5.1 创建 存储 过 程 


在 PHPMyAdmin 中 ,可 以 使 用 可 视 化 和 语句 两 种 方式 创建 存储 过 程 。 
1. 创建 存储 过 程 的 可 视 化 操作 


可 视 化 创建 存储 过 程 的 操作 方法 : 在 PHPMyAdmin 主页 ,选择 当前 数据 库 , 单 击 “ 程 
序 " 选 项 卡 王 添加 程序 "按钮 ,在 “添加 程序 "窗口 设置 相关 参数 ,编辑 程序 代码 ,最 后 单 
击 “ 执 行 "按钮 。 

【 例 5.12】 在 PHPMyAdmin 中 ,通过 可 视 化 方式 在 RCZP 数据 库 中 设计 存储 过 程 
evenwith ,设置 整 型 参数 m, 用 于 实现 1 +2 +3 +…+ 的 累加 运算 ,通过 参数 返回 运算 
结果 。 

设计 步骤 及 说 明 如 下 : 

(1) 在 PHPMyAdmin 主页 ,选择 RCZP 为 当前 数据 库 , 单 击 “ 程 序 "选项 卡 一 “添加 程 
序 " 按 钮 ,进入 “添加 程序 "窗口 ,如 图 5-7 所 示 。 
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图 5-7 存储 过 程 编辑 对 话 框 
(2) 程序 名 称 : 为 存储 过 程 或 函数 命名 ,命名 规则 与 数据 表 名 相同 ,但 不 可 与 系统 函 
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数 同名 ,如 evenwith 。 

(3) 类 型 : 选择 过 程式 数据 库 对 象 的 类 型 ,有 Procedure 和 Function ,Procedure 表示 存 
储 过 程 ,Function 表示 存储 函数 。 

(4) 方向 : 选择 形 参 的 数据 传递 方向 。 其 含义 如 下 : 

。 In: 输入 参数 ,调用 存储 过 程 时 , 仅 接收 由 实际 参数 传 来 的 数据 。 

。 Out: 输出 参数 ,调用 存储 过 程 结束 后 ,通过 形 参与 实际 参数 变量 的 对 应 关系 ,由 实 

际 参 数 获取 返回 值 。 
。 InOut: 输入 /输出 参数 , 既 能 接收 实际 参数 传 来 的 数据 ,又 能 将 形式 参数 的 值 返回 
给 实际 参数 变量 。 

(5) 名 字 : 形式 参数 名 ,简称 形 参 名 。 可 以 有 多 个 形 参 ,也 可 以 没有 形 参 。 形 参 不 能 
用 数据 表 中 的 字段 名 ,否则 ,执行 存储 过 程 时 可 能 会 出 现 不 可 预知 的 结果 。 如 mn。 

(6) 参数 类 型 . 为 形 参 选择 数据 类 型 Char .VarChar .Date .DateTime ,Int 和 Real 等 , 例 
如 为 参数 n 选择 Int 类 型 。 

(7) 编辑 过 程 体 代码 : 用 于 编辑 程序 代码 ,每 条 语句 由 分 号 结束 ,如 图 5-7 所 示 。 

(8) 创建 存储 过 程 : 单 击 “ 执 行 "按钮 ,保存 程序 并 创建 了 存储 过 程 evenwith。 

2. 创建 存储 过 程 的 语句 

语句 结构 : 

Create Procedure [ 数据 库 名 >.] < 存储 过 程 名 >( 

[In IOut IInout < 形式 参数 名 1 > 数据 类 型 1 >[,…]]) 
< 存储 过 程 体 > 

相关 项 的 含义 如 下 : 

(1) [数据 库 名 . ] 存 储 过 程 名 : 在 指定 数据 库 中 创建 存储 过 程 ,在 当前 数据 库 中 创建 
存储 过 程 时 ,数据库 名 可 以 省 略 。 

(2) 形式 参数 名 : 定义 形式 参数 ,多 个 形 参 之 间 用 逗号 分 隔 。 

(3) 数据 类 型 : 指定 形 参 的 数据 类 型 。 

(4) 存储 过 程 体 : 完成 存储 过 程 功 能 的 程序 代码 ,其 中 语句 可 以 是 SQL 语句 ,如 
Create \Update 和 Select 等 ,也 可 以 是 过 程式 的 语句 ,如 分 支 语句 循环 语 句 .变量 声明 . 变 
量 赋值 及 游标 等 。 

3. 执行 创建 存储 过 程 的 语句 

在 MySQL 命令 窗口 和 MySQL 语句 输入 及 执行 窗口 中 ,都 可 以 执行 创建 存储 过 程 的 
语句 ,实施 创建 存储 过 程 。 为 了 区 别 存 储 过 程 体 中 的 MySQL 语句 与 Create Procedure 语 
句 结构 自身 的 结束 符 分 号 “ ;” ,在 执行 Create Procedure 语句 之 前 需要 用 Delimiter 语句 定 
义 其 结构 的 结束 符号 。 

语句 格式 : 


Delimiter < 两 个 连续 相同 字符 > 
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Delimiter 语句 中 两 个 连续 的 符号 通常 用 特殊 符号 ,如 // 、$ $ 或 && 等 。 

【 例 5.13】 在 MySQL 命令 行 创建 存储 过 程 gwb_xl_rs ,如果 第 一 个 参数 值 为 0, 则 统 
计 gwb 表 中 各 学 历 招 聘 人 数 , 否 则 ,统计 各 学 位 招聘 人 数 。 通 过 函数 参数 返回 各 个 统计 结 
果 。 

(1) 单 击 XAMPP 控制 面板 中 的 Shell 按钮 ,在 命令 行 输入 如 下 命令 来 登录 MySQL: 


Mysql uywy 了 了 
(2) 在 系统 提示 Enter password 后 ,输入 密码 ywy211 并 按 Enter 键 ,进入 MySQL 提示 


符 。 
(3) 依次 输入 如 下 命令 ,创建 存储 过 程 : 
Use RCZP; /* 打开 RCZP 数据库 ,使 之 成 为 当前 数据 库 * / 
Delimiter 大 /* 定义 SQL 语句 的 结束 标识 为 大 / 


Create Procedure gwb xl rs (InOut zrs int,Out rsl int,Out rs2 int, 
Out rs3 int,Out rs4 int,Out rs5 int) 
Begin 
Declare done Boolean Default True; 
Declare zdx] Char (1); 
Declare rs TinyInt (3); 
Declare curl Cursor For Select 最 低 学 历 , 人 数 From gwb; /* 创建 学 历 游标 curl * / 
Declare cur2 Cursor For Select 最 低 学 位 ,人 数 From gwb; /+*# 创建 学 位 游标 cur2 * / 
Declare continue handler for not found set done =false; 
Set rsl 0, rs2 -0, rs3 0, rs4 0, rs5 0; 
If zrs -0 Then 
Open curl; /* 打开 游标 curl * / 
Fetch curl Into zdx],rs; 
/* 获取 游标 curl 中 的 第 1 行 数据 ,保存 在 zdxl 和 rs 变量 中 */ 
Else 
Open cur2; /* 打开 游标 cur2 * / 
Fetch cur2 Into zdx], rs; 
/* 获取 游标 cur2 中 的 第 1 行 数据 ,保存 在 zdxl 和 rs 变量 中 * / 


End if; 
While done do /* 成 功 获取 游标 中 的 数据 * / 
Case zdxl /* 判断 最 低 学 历 的 值 , 将 招聘 人 事 累 加 到 对 应 的 变量 中 * / 


When '1' Then Set rsl =rsl +rs7 
When '2' Then Set rs2 =rs2 +Hrs7 
When '3" Then Set rs3 =rs3 +rs; 
When '4' Then Set rs4 =rs4 +rs7 
When '5' Then Set rs5 =rs5 +rs7 


End Case; 

If zrs -0 Then Fetch curl Into zdxl,rs; /* 获取 游标 curl 中 的 下 一 行 数据 * / 
Else Fetch cur2 Into zdx], rs; /* 获取 游标 cur2 中 的 下 一 行 数据 * / 
End if; 
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End While; 


If zrs -0 Then Close curl; /* 关闭 游标 curl * / 

Else Close cur2; /* 关闭 游标 cur2 * / 

End if; 

Set zrs =rsl1 +rs2 +rs3 +rs4 +rs5; 
End 大 /* 完整 的 存储 过 程 结 束 符 为 大 / 
Delimiter ; /* 恢复 MyseL 语 句 结 束 标识 为 *;”* / 


(4) 输入 最 后 一 行内 容 回 车 后 ,系统 提示 Query OK ,0 row affected (0.00sec) ,表示 存 
储 过 程 创建 完成 。 


5.5.2 调用 存储 过 程 


在 程序 .触发 器 或 者 其 他 存储 过 程 的 代码 中 均 可 以 运行 Call 语句 调用 存储 过 程 。 

语句 格式 : 

Call [ 数据 库 名 .] < 存储 过 程 名 >([ 实际 参数 1 [,…] ]) 

(1) 当 Call 语句 调用 非 当 前 数据 库 中 的 存储 过 程 时 ,需要 指定 数据 库 名 。 

(2) 当 所 调用 的 存储 过 程 没有 参数 时 ,存储 过 程 名 后 的 一 对 圆 括号 不 能 省 略 。 

(3) 当 存储 过 程 有 参数 时 ,实际 参数 必须 与 形式 参数 个 数 相同 。 

(4) 当 形 参 方向 选择 为 In 时 ,对 应 的 实 参 可 以 是 常量 变量 或 表达 式 ; 当 形 参 方向 选择 
为 Out 或 InOut 时 , 实 参 只 能 是 变量 ,在 命令 行 应 用 中 实 参 必须 使 用 全 局 变量 (@ 开头 ) 。 

【 例 5.14】 在 MySQL 命令 行 中 调用 例 5. 12 创建 的 RCZP 数据 库 中 的 存储 过 程 
evenwith ,分 别 输出 1 ~10 和 1~100 的 累加 结果 。 

在 MySQL 提示 符 下 依次 输入 如 下 命令 : 

Use RCZP; -打开 RCZP 数据 库 使 其 成 为 当前 数据 库 

Set @n1 导 0,8n2 导 00;  -- 设 置 全 局 变量 nl,n2 并 分 别 赋值 

Call evenwith(@n1); ”-- 调 用 存储 过 程 esvenwith, 计 算 enl 的 累加 值 并 将 结果 存储 于 enl 中 


Call evenwith(@n2); ， -- 调 用 存储 过 程 evenwith, 计 算 e@n2 的 累加 值 并 将 结果 存储 于 en2 中 
Select enl,en2; -- 显 示 enl,en2 的 值 ,结果 为 55,5050 


【 例 5.15】 在 MySQL 命令 行 中 调用 例 5. 13 创建 的 存储 过 程 gwb_xl_rs ,分 别 统计 
gwb 中 各 学 历 及 各 学 位 招聘 的 总 人 数 。 
在 MySQL 命令 行 提 示 符 “mysql > ”后 依次 输入 如 下 语句 : 


Use RCZP; 赃 择 RCZP 为 当前 数据 库 

Set @zs 0; 投 置 第 一 个 实 参 的 值 

Call gwb xl rs(@zs,@rsl,@rs2,@rs3,@rs4,@rs5); 拦 用 存储 过 程 统计 各 学 历 人 数 
Select @zs Rs 总 数 ,@ rsl Rs 无 学 历 ,@rs2 Rs 专科 ,ers3 As 本 科 ， 

Q@rs4 as 研究 生 ，@rs5 As 博士 ; 气 示 统计 结果 

Set zs 本; 投 置 第 一 个 实 参 的 值 , 非 零 , 用 来 统计 学 位 人 数 
Call gwb xl rs (ezs,@rsl,ers2,8Qrs3,@rs4,Brs5) 7 薪 用 存储 过 程 统 计 各 学 位 人 数 
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Select @zs As 总 数 ,@ rsl Rs 无 要 求 ,@rs2 Rs 学 士 , @rs3 As 双 学 士 ， 
@rs4 Rs 硕士 ,ers5 Rs 博士 ; 提示 统计 结果 


调用 存储 过 程 及 结果 ,如 图 5-8 所 示 。 





了 
国 管理 员 : XAMPP for Windows - mysql -uroot -P "加 


t 《9.98 sec) 

















图 5-8 存储 过 程 gwb_xl_rs 的 执行 过 程 及 结果 窗口 


5.5.3 ”删除 存储 过 程 
在 MySQL 中 可 以 通过 语句 和 可 视 化 操作 删除 数据 库 中 的 存储 过 程 
1. 删除 存储 过 程 的 语句 
语句 格式 : 
Drop Procedure [If Exists] < 存储 过 程 名 > 
语句 中 只 需要 给 出 存储 过 程 名 。 删 除 存储 过 程 前 需要 确认 该 存储 过 程 没 被 其 他 存储 


过 程 .触发 或 程序 调用 ,否则 会 导致 其 他 调 用 无 法 运行 
【 例 5.16】 在 MySQL 命令 行 中 ,删除 RCZP 数据 库 中 的 存储 过 程 evenwith 


Use RCZP; 
Drop Procedure if Exists evenwith; 


2. 删除 存储 过 程 的 操作 
在 PHPMyAdmin 中 也 可 以 删除 存储 过 程 : 选 定数 据 库 名 ( 如 RCZP) ,在 “程序 "选项 
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卡 中 , 单 击 要 删除 过 程 名 所 在 行 的 “删除 ”选项 和 “确定 ”按钮 。 
5.6 存储 函数 设计 


存储 函数 与 存储 过 程 类 似 ,也 是 一 组 有 序 的 MySQL 语句 集合 ,保存 在 数据 库 中 ,可 以 
被 程序 和 MySQL 语句 调用 。 存 储 函 数 与 存储 过 程 主要 有 如 下 几 点 差别 : 

(1) 创建 语句 关键 字 不 同 。 用 Create Procedure 语句 创建 存储 过 程 ，Create Function 
语句 创建 存储 函数 。 

(2) 形式 参数 方向 不 同 。 存 储 过 程 参 数 需 要 用 m .Out 或 InOut 进行 说 明 ,省 略 方向 
说 明 时 默认 为 In; 存 储 函数 的 参数 不 使 用 方向 说 明 , 所 有 参数 均 为 输入 参数 (相当 于 存储 
过 程 中 的 m) 。 

(3) 有 无 返回 值 。 存 储 过 程 没 有 返回 值 ,存储 函数 必须 有 返回 值 ,因此 ,在 定义 的 存 
储 函 数 名 后 使 用 Returns 短语 说 明 返 回 值 类 型 。 

(4) 过 程 体内 的 代码 限制 。 存 储 过 程 体内 可 以 写 任何 MySQL 语句 ,但 是 ,存储 函数 
体内 使 用 查询 语句 (Select) 时 ,只 能 用 Select … Into … From 语句 。 

(5) 出 口 个 数 不 同 。 存 储 过 程 体 只 有 最 后 一 个 出 口 ;存储 函数 体 中 可 以 有 多 条 
Retum( < 表达 式 > ) 语 句 , 即 可 能 有 多 个 出 口 。 

(6) 调用 方法 不 同 。 用 Call 语句 调用 存储 过 程 ,通过 Out 或 InOut 形式 参数 与 实 参 
全 局 变量 的 对 应 关系 带 回 多 个 值 ;在 表达 式 中 用 调用 系统 函数 的 方法 调用 存储 函数 ,存储 
函数 只 能 带 回 一 个 值 。 


5.6.1 创建 存储 函数 


通过 MySQL 语句 和 PHPMyAdmin 可 视 化 数据 库 管 理 平台 均 可 以 创建 存储 函数 。 
1. 创建 存储 函数 的 可 视 化 操作 


操作 方法 与 可 视 化 创建 存储 过 程 类 似 , 如 图 5-7 所 示 ,“ 类 型 " 换 为 FUNCTION; 从 增 
加 的 “返回 类 型 "中 选择 函数 返回 值 的 数据 类 型 等 ,最 后 单 击 * 执 行 ”按钮 保存 函数 。 


2. 创建 存储 函数 的 语句 
语句 格式 ; 


Create ”Function [ 数据库 名 >.] < 存储 函数 名 >( 
[ < 形式 参数 名 1 > ”数据 类 型 1 习 […]) 
Returns < 函数 返回 值 数据 类 型 > 
[Begin] 
< 语句 序列 > 
[End] 
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创建 存储 函数 语句 与 创建 存储 过 程 相似 ,相关 项 的 含义 也 基本 相同 。 函 数 体内 必须 
用 Retum( < 表达 式 > ) 语 句 ,表达 式 的 值 为 函数 的 返回 值 ,数据 类 型 应 与 函数 说 明 中 
Retums 短语 的 类 型 一 致 。 函 数 返回 值 可 以 是 常量 .变量 .表达 式 或 Select 语句 的 查询 结 
果 , 若 用 Select 语句 的 结果 作为 返回 值 , 则 只 能 是 一 行 且 一 列 值 。 过 程 体 中 可 以 出 现 多 条 
Return( < 表达 式 > ) 语 句 , 通 常用 在 分 支 语句 结构 中 , 某 次 调用 函数 只 能 执行 一 条 Retum 
(< 表达 式 > ) 语 句 , 结 束 函数 调用 ,返回 一 个 值 。 

【 例 5.17】 在 RCZP 库 中 创建 存储 函数 ypryb_lxdh ,用 于 检索 应 聘 人 员 的 联系 电话 ， 
其 中 参数 为 身份 证 号 ,函数 返回 值 为 应 聘 人 员 的 固定 电话 及 移动 电话 号 码 

在 MySQL 命令 行 (如 图 5-9 所 示 ) 分 别 输入 如 下 语句 并 回 车 执行 : 


eh 





Use RCZP; 打开 RCZP 数据 库 
Create Function ypryb_lxdh (SFZH CHAR (18) ) Returns Varchar (40) 
Return (select concat (固定 电话 ,' ,移动 电话 ) as 联系 电话 From RCZP.ypryb 


Where 身份 证 号 <SFZH) ; 手 | 建 存储 过 程 ypryb_lxdh 
Select ypryb lxdh ("229901199503121538'); 搓 用 存储 函数 查看 结果 
国 管理 员 : XAMPP for Windows - MYSQL -uroot 上 yx 

















图 5-9 存储 函数 ypryb_lxdh 的 应 用 


ypryb 表 中 有 固定 电话 ( varchar(20) ) 和 移动 电话 ( varchar(15 ) ) 两 个 字段 ,函数 要 求 
隔 ,类 型 及 长 度 与 函数 中 说 明 返 回 值 的 类 型 VarChar(40 ) 相 匹配 
5.6.2 调用 和 管理 存储 函数 


1. 调用 存储 函数 

存储 函数 与 系统 函数 的 调用 方法 相同 ,存储 函数 调用 通常 出 现在 表达 式 中 。 所 谓 调 
用 存储 函数 就 是 转 去 执行 存储 函数 体 中 的 语句 ,执行 到 Retum( < 表达 式 > ) 语 句 后 , 返 
回 到 调用 语句 并 带 回 函数 的 返回 值 。 

调用 格式 : < 存储 函数 名 > ([ < 实际 参数 表 > ] ) 
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实际 参数 ( 实 参 ) 应 该 与 定义 存储 函数 时 的 形 参 一 一 对 应 ,多 个 实 参 之 间 用 “, ”分隔 。 
如 果 创建 的 存储 函数 没有 形式 参数 , 则 调用 时 函数 名 后 的 一 对 圆 括号 不 能 省 略 。 

2. 查看 存储 函数 的 语句 

执行 下 列 语句 可 以 查看 当前 数据 库 中 有 哪些 存储 函数 名 。 

语句 格式 : 

Show Function Status 


执行 下 列 语句 查看 存储 函数 的 具体 定义 格式 。 
语句 格式 : 


Show Create Function [ < 数据 名 >.] < 存储 函数 名 > 


【 例 5.18】 在 MySQL 命令 行 查看 RCZP 数据 库 中 的 存储 过 程 及 存储 函数 名 ,显示 存 
储 函 数 ypryb_lxdh 的 定义 语句 。 


Use RCZP ; 打开 RCZP 数据 库 , 使 之 成 为 当前 数据 库 
Show Function Status; 得 看 当前 数据 库 中 有 哪些 存储 函数 定义 
Show Procedure Status; 得 看 当前 数据 库 中 有 哪些 存储 过 程 定义 
Show Create Function ypryb_ lxdh; 得 看 存储 函数 ypryb_lxdh 的 定义 语句 


3. 删除 存储 函数 的 语句 

用 Drop 语句 可 以 删除 存储 函数 ,用 法 与 删除 存储 过 程 相同 。 
语句 格式 : 

Drop Function [ If Exists ] [< 数据 库 名 >.] < 存储 函数 名 > 

【 例 5.19】 运行 Drop Function 语句 删除 存储 函数 ypryb_lxdh。 


Drop Function If Exists rczp.ypryb lxdh; 


5.7 触发 器 设计 


触发 器 是 一 种 与 数据 表 关 联 的 数据 库 对 象 ,对 关联 表 进 行 特定 操作 (也 称 事件 ,如 更 
新 .增加 或 删除 数据 记录 ) 时 ,系统 自动 执行 触发 器 的 程序 代码 。 例 如 ,对 YPRYB 表 设 计 
更 新 数据 ( Update ) 触发 器 后 ,在 更 新 YPRYB 表 中 的 数据 时 (可 视 化 直接 修改 或 执行 
Update 语句 ) ,系统 会 自动 执行 触发 器 中 的 程序 代码 。 

设计 触发 器 的 目的 是 确保 数据 表 中 的 数据 发 生变 化 前 后 ,使 得 某 些 特殊 操作 (如 数 
据 备份 .操作 日 志和 数据 校 验 等 ) 能 够 得 到 及 时 实施 ,以 便 保证 数据 的 一 致 性 .完整 性 、 正 
确 性 以 及 可 维护 性 。 
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5.7.1 创建 触发 器 


用 户 需要 有 Trigger 权限 才能 创建 或 删除 触发 器 。 通 过 MySQL 命令 方式 和 
PHPMyAdmin 可 视 化 数据 库 管理 平台 均 可 创建 触发 器 。 


1. 创建 触发 器 的 可 视 化 操作 


(1) 在 PHPMyAdmin 主页 ,选择 当前 数据 库 ( 如 RCZP) 。 
(2) 单 击 * 触 发 器 "选项 卡 的 “添加 触发 器 "按钮 。 在 “添加 触发 器 "窗口 中 设置 参 
数 ,如 输入 "触发 器 名 称 " 为 ypryb_update_backup ,选择 “ 表 " 为 ypryb,“ 时 机 ”为 BEFORE， 
“事件 "为 UPDATE。 在 “定义 " 框 中 编写 代码 ,如 图 5-10 所 示 , 单 击 * 执 行 " 按 钮 。 





























EE | 
[3] 
裔 发 器 名 称 |ypryb_update_backup 
表 |ypryb 器 | 
时 机 | BEFORE 多 
事件 | upDATE 加 








1 insert into ypryb bak select now(),ypryb.* from ypryb 
where 身份 让 号 =new. 身 份 证 吕 ; 
定义 

















执行 关闭 








图 5-10 触发 器 编辑 窗口 


2. 创建 触发 器 的 语句 
语句 格式 ， 


Create Trigger [ 数据库 名 >.] < 触发 器 名 > 
Before IAfter 人 事件 名 称 >on < 表 名 普 or Each Row 
[Begin] 
< 语句 序列 > 
[End] 
相关 项 的 含义 如 下 : 
(1) [数据 库 . ] < 触发 器 名 > : 在 一 个 数据 库 中 触发 器 名 必须 唯一 ,在 当前 数据 库 
中 添加 触发 器 ,可 以 省 略 “ < 数据 库 名 > . "选项 。 
(2) Before1After: 称 为 触发 时 机 ,规定 在 发 生 事件 前 ( Before ) 或 发 生 事件 后 ( After) 
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执行 触发 器 的 程序 代码 。 
(3) 事件 名 称 : 必须 是 Insert .Update 或 Delete 事件 之 一 。 
e Insert: 向 数据 表 中 增加 记录 存盘 之 前 ( Before) 或 之 后 ( After) 执行 触发 器 的 程序 


代码 。 
。 Update: 修改 数据 表 中 数据 存盘 之 前 ( Before ) 或 之 后 ( After) 执行 触发 器 的 程序 
代码 。 


se Delete: 删除 数据 表 中 记录 存盘 之 前 (Before ) 或 之 后 ( After) 执 行 触发 器 的 程序 代码 。 

(4) < 表 名 > : 要 添加 触发 器 的 表 名 ,必须 是 数据 表 , 不 能 为 临时 表 或 视图 。 

(5) For Each Row: 对 每 条 操作 记录 都 执行 触发 器 的 程序 代码 。 

(6) 程序 代码 : 发 生 相 关 事件 之 前 (Before) 或 之 后 ( After) 要 执行 的 程序 代码 。 如 果 
仅 需 要 一 条 语句 , 则 可 以 省 略 Begin 和 End; 若 程序 含 多 条 语句 , 则 必须 用 Begin…End 构 
建 复合 语句 。 

每 个 数据 表 都 有 Insert .Update 和 Delete 三 个 事件 ,每 个 事件 还 有 Before 和 After 两 个 
触发 时 机 ,因此 ,对 每 个 表 可 以 设计 多 达 6 个 触发 器 。 从 触发 器 的 角度 来 看 ,一 个 触发 器 
只 能 关联 一 个 数据 表 的 一 个 事件 及 触发 时 机 。 

在 触发 句 代 码 中 可 以 使 用 别名 为 01d 或 New 的 虚拟 表 , 名 称 不 区 分 大 小 写 。 对 Insert 
触发 器 ,只 能 使 用 New ,存储 要 插入 到 表 中 的 数据 记录 ;对 Delete 触发 器 ,只 能 使 用 01d, 存 
储 要 被 删除 的 数据 记录 ;对 Update 触发 器 ,可 以 同时 使 用 Old 和 New, 其 中 Old 存储 操作 
前 原 表 中 的 数据 ,New 存储 更 新 后 的 数据 。 

【 例 5.20】 在 RCZP 数据 库 中 创建 触发 器 ypryb_update_backup。 当 修改 YPRYB 表 
中 的 任 一 记录 时 ,触发 器 自动 将 更 新 前 的 记录 内 容 进行 备份 ,备份 结果 保存 在 ypryb_bak 
表 ( 与 ypryb 同 结构 ) 中 ,同时 在 备份 表 ypryb_bak 中 记录 更 新 记录 时 的 日 期 时 间 值 。 

(1) 创建 备份 表 文 件 : 在 MySQL 命令 行 依次 输入 如 下 语句 并 回 车 执行 。 

Use RCZP; -- 打 开 RCzP 数 据 库 ,使 之 成 为 当前 数据 库 

Create Table If Not Exists ypryb bak like ypryb; -复制 表 结构 

Alter Table ypryb bak Add 时 间 Datetime First; 

-在 ypryb_bak 表 中 添加 时 间 字 段 , 类 型 为 datetime, 作 为 表 中 第 一 个 字段 

Alter Table ypryb bak Drop Primary Key; - -删除 ypryb_bak 中 的 关键 字 

Alter Table ypryb bak Add Primary Key (时 间 , 身 份 证 号 ) ; ”-- 为 ypryb_bak 表 重 新 设 定 关 键 字 

(2) 创建 触发 器 : 通过 触发 器 保存 更 新 前 的 数据 ,选择 触发 事件 为 Update ,触发 时 机 
选择 Before ,操作 的 表 是 ypryb ,其 Mysql 语句 如 下 : 


Create Trigger RCZP.ypryb update backup Before Update On RCZP.ypryb 
For Each Row Insert Into ypryb bak Select Now () ,ypryb. * From ypryb 
Where 身份 证 号 New. 身 份 证 号 ; 


(3) 测试 触发 器 : 执行 Update 语句 修改 ypryb 表 中 的 数据 ,查看 触发 器 的 执行 效果 。 


Select * From ypryb Where 邮政 编码 "130012"; 制 览 修改 前 ypryb 中 的 数据 
update ypryb Set 邮政 编码 ="130018" where 邮政 编码 =2"130012"; 
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将 ypryb 表 中 的 所 有 邮政 编码 130012 修改 为 130018 
Select * From ypryb Where 邮政 编码 ="130018"; 制 览 修改 后 的 Ypryb 表 中 数据 
Select * From ypryb bak; 判 览 通过 触发 器 备份 的 Ypryb bak 表 中 数据 


5.7.2 查看 与 编辑 触发 器 


1. 查看 触发 器 的 可 视 化 操作 


在 PHPMyAdmin 主页 ,选择 当前 数据 库 ( 如 RCZP) , 单 击 * 触 发 器 "选项 卡 的 触发 器 行 
“编辑 ”按钮 ,进入 触发 器 设计 界面 。 修 改 内 容 后 单 击 “ 执 行 ”按钮 , 即 可 保存 修改 结果 。 


2. 查看 触发 器 的 语 名 


在 MySQL 命令 行 中 , 若 需 要 查看 触发 器 名 称 ,可 以 使 用 Show Triggers 语句 。 
语句 格式 : 


Show Triggers [ <Erom | in 激 据 库 名 ] 
【 例 5.21】 在 MySQL 命令 行 客 户 端 中 查看 RCZP 数据 库 中 的 触发 器 定义 。 
Use RCZP; 投 置 RCZP 为 当前 数据 库 


Show Triggers; 查看 当前 数据 库 中 的 触发 器 


5.7.3 删除 触发 器 

当 删除 一 个 表 时 ,会 自动 删除 该 表 相 关 的 触发 器 。 此 外 ,通过 MySQL 命令 方式 和 
PHPMyAdmin 可 视 化 数据 库 管 理 平台 均 可 以 删除 触发 器 。 

1. 删除 触发 器 的 可 视 化 操作 


在 PHPMyAdmin 主页 , 选 定数 据 库 名 (如 RCZP) 一 “触发 器 "选项 卡 ,在 “触发 器 " 信 
息 框 中 单 击 要 删除 触发 器 (如 ypryb_Update_backup) 行 的 “删除 "按钮 ,在 确认 对 话 框 中 单 





2. 删除 触发 器 的 语句 
语句 格式 : 


Drop Trigger [ If Exists ] [ < 数据 库 名 >.] < 触发 器 名 > 
【 例 5.22】 删除 RCZP 数据 库 中 ypryb 表 的 ypryb_Update_backup 触发 器 。 


Use RCZP; 珊 置 RCZP 为 当前 数据 库 
Drop Trigger If Exists ypryb _ Update backup; 


制 除 当前 数据 库 中 的 ypryb_update_backup 触发 器 
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5.8 事件 设计 


事件 是 基于 特定 时 间 周 期 触发 执行 某 些 任务 ,例如 ,每 星期 或 每 个 月 数据 库 的 备份 工 
作 , 依 靠 MySQL 服务 器 中 的 事件 调度 器 功能 模块 进行 监控 。 事 件 调度 器 可 以 将 事件 的 启 
动 时 间 精 确 到 秒 , 这 对 实时 性 要 求 较 高 的 数据 处 理 任务 尤其 实用 。 


5.8.1 开局 事件 调度 器 

使 用 事件 调度 器 之 前 ,需要 在 服务 器 端 开启 事件 调度 器 ,设置 Event_Scheduler 参数 
为 True 或 1。 

1. 查看 事件 调度 器 的 状态 

运行 下 列 语句 可 以 查看 事件 调度 器 的 状态 。 

语句 格式 : 

Show Variables Like 'Event Scheduler'; 

若 显 示 Event_Scheduler 的 值 为 Of, 表 示 事 件 调度 器 处 于 关闭 状态 ; 若 显 示 Event_ 
Scheduler 的 值 为 On ,表示 事件 调度 器 处 于 开启 状态 。 

2. 开启 与 关闭 事件 调度 器 

(1) 运行 下 列 语句 可 以 开启 或 关闭 事件 调度 器 。 

语句 格式 : 

Set Global Event Scheduler 习 或 0; 


(2) 在 MySQL 的 配置 文件 my. ini 中 开启 事件 调度 器 ,方法 为 单 击 XAMPP 控制 面板 
中 MySQL 行 的 Config 按钮 一 my. ini, 在 记事 本 中 查找 [mysqld] 项 ,在 其 下 方 增加 如 下 语 
句 行 : 

Event Scheduler 习 或 


Set Global Event Scheduler -On 


则 每 次 启动 XAMPP 时 ,自动 启动 事件 调度 器 。 
5.8.2 创建 事件 


通过 MySQL 语句 Create Event 及 PHPMyAdmin 可 视 化 数据 库 管 理 平台 都 可 以 创建 事 
i 
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1. 创建 事件 的 可 视 化 操作 


在 PHPMyAdmin 主页 ,选择 当前 数据 库 ( 如 RCZP) , 单 击 * 事 件 " 选 项 卡 的 “添加 习 
件 " 按 钮 ,在 “添加 事件 "窗口 中 ,设置 事件 的 有 关 信 息 , 如 输入 “事件 名 称 " 为 ypryb_ 
backup ;选择 “状态 "为 ENABLED, “事件 类 型 为 RECURRING, “运行 周期 "为 1 WEEK 
等 。 在 定义 框 中 输入 事件 代码 ,如 图 5-11 所 示 ,最 后 单 击 * 执 行 "按钮 。 





ul 











还 加 事件 | 

详细 上 

事件 名 称 ypryb_backup 

状态 ENABLED 回 
事件 类 型 RECURRING 局 
运行 周期 1 WEEK Ea 
起 拍 时 间 2017-11-25 00:00:00 图 
终止 时 间 2021-01-01 00:00:00 回 


ze *d:/ypryb.exe™ 








图 5-11 事件 编辑 窗口 


2. 创建 事件 的 语句 
语句 格式 : 
Create Event [If Not Exists] 事件 名 >on Schedule 
At < 时 间 >[ +Interval < 时 间 间 隔 习 
1 Every < 时 间 间 隔 >[Starts < 开始 时 间 >[ +Interval < 时 间 间 隔 3]] 
[Ends < 结束 时 间 >[ +Interval < 时 间 间 隔 习 ] 
Do < 语句 序列 > 


相关 项 的 含义 说 明 如 下 : 

(1) < 时 间 > : 表示 触发 事件 的 时 间 点 。 

(2) < 时 间 间 隔 > : 由 数值 与 时 间 单 位 两 部 分 组 成 。 时 间 单 位 可 以 是 Year .Quarter、 
Month Week .Day .Hour .Minute .Second ,Year_month 或 Day_hour 之 一 。 

(3) Every: 表示 每 隔 多 长 时 间 发 生 一 次 事件 。 

(4) Starts: 指定 起 始 时间 。 

(5) Ends: 指定 终止 时 间 。 

【 例 5.23】 在 数据 库 RCZP 中 创建 ypryb_backup 事件 : 从 当前 时 间 算 起 ,2 分 钟 后 
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备份 一 次 ypryb 表 , 之 后 每 间隔 1 星期 备份 一 次 ,备份 文件 以 “ypryb”+ < 系统 日 期 > + 
“.txt" 作 为 文件 名 存放 到 D 盘 根 文件 夹 下 ,备份 文件 中 的 数据 用 逗号 分 隔 , 直 到 2028 年 
12 月 31 日 截止 。 


Delimiter $$ -定义 语句 的 结束 标识 
Create Event If Not Exists ypryb backup 
On Schedule Every 1 Week 
Starts Curdate () +Interval 2 minute Ends '2028 2 31" 


Do 
Begin 
Set @ SQL =concat ("Select * From ypryb Into OutFile 'd:/ypryb",CurDate (),".txt 
i £2 
-- 生 成 动态 SQL 语句 ,备份 的 文件 名 中 包含 当前 日 期 

Prepare Execsql From @ SQL; =- - 预 处 理 动态 语句 
Execute Execsq]; -执行 预 处 理 后 的 SQL 语句 

End $$ 

Delimiter ; /* 恢复 MysQr 语句 的 结束 标识 为 

机 


5.8.3 修改 事件 


1. 修改 事件 的 可 视 化 操作 


在 PHPMyAdmin 主页 ,选择 当前 数据 库 ( 如 RCZP) ,在 “事件 "选项 卡 中 单 击 事件 (如 
ypryb_backup ) 行 的 “编辑 "按钮 。 在 “编辑 事件 "窗口 编辑 各 项 内 容 ,最 后 单 击 “ 执 行 " 按 
钮 ,保存 修改 内 容 。 


2. 修改 事件 的 语句 
语句 格式 : 
Rlter Event < 事件 名 >[Rename To < 新 事件 名 习 
[On Schedule At < 时 间 >[ +Interval < 时 间 间 隔 习 
IEvery < 时 间 间 隔 >[Starts < 开始 时 间 >[ +Interval < 时 间 间 陋习 ] 
[Ends < 结束 时 间 >[ +Interval < 时 间 间 隔 习 ]] 
[Enable | Disable] [Do 执行 语句 序列 习 
Rename To < 新 事件 名 > 短语 为 事件 更 改名 称 。Enable 短语 启动 事件 , Disable 短语 
临时 关闭 事件 。 其 他 相关 项 含义 同 Create Event 语句 。 
【 例 5.24】 将 事件 ypryb_backup 改名 为 backup_ypryb。 


Use rczp; /* 打开 RCZP 数 据 库 * / 
Alter Event ypryb backup Rename To backup ypryb; /* 事件 改名 * / 
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5.8.4 删除 事件 


1. 删除 事件 的 可 视 化 操作 


在 PHPMyAdmin 主页 ,选择 当前 数据 库 ( 如 RCZP) ,在 “事件 "选项 卡 中 单 击 事件 (如 
backup_ypryb) 行 的 “删除 "一 “确定 "按钮 。 


2. 删除 事件 的 语句 
语句 格式 : 
Drop Event [If Exists] < 事件 名 > 


If Exists 短语 ,只 删除 已 有 的 事件 ,避免 删除 不 存在 的 事件 而 引起 错误 。 
【 例 5.25】 删除 事件 backup_ypryb。 


Use rczp; /* 打开 rczp 数 据 库 * / 
Drop Event If Exists backup ypryb; 


5.9 在 动态 网 页 中 调用 存储 过 程 及 函数 


PHP 是 设计 动态 网 页 的 程序 设计 语言 之 一 ,在 PHP 操作 (执行 语句 ) MySQL 数据 库 
管理 系统 及 其 对 象 (数据 表 、 存 储 函 数 及 存储 过 程 ) 时 ,需要 调用 函数 MySQL_Connect( ) 
连接 数据 库 服 务 器 ;调用 函数 MySQL_Select_DB ( ) 选择 要 操作 的 数据 库 ;调用 函数 
MySQL_Query( ) 发送 MySQL 语句 ;调用 函数 MySQL_Fetch_Row( ) 返 回 操作 结果 ;调用 也 
数 MySQL_Close( ) 断 开 数 据 库 服务 器 的 连接 。 


5.9.1 PHP 调用 存储 函数 


PHP 程序 要 操作 MySQL 数据 库 管 理 系 统 ,需要 向 MySQL 发 送 相关 语句 ;要 获取 
MySQL 的 操作 结果 ,通常 要 发 送 Select 语句 。PHP 程序 中 用 “//”" 作 为 语句 的 行 尾 注释 。 

【 例 5.26】 在 PHP 中 ,调用 RCZP 库 中 的 存储 函数 ypryb_lxdh( ) 来 查询 身份 证 号 为 
229901199503121538 的 应 聘 人 员 的 联系 方式 ,结果 显示 在 浏览 器 页 面 中 。 

(1) 创建 PHP 文件 : 启动 Dreamweaver, 单 击 “ 文 件 " 菜 单一 “新 建 " 一 “空白 页 ”一 
PHP 一 “创建 "按钮 。 

(2) 输入 PHP 程序 代码 : 在 代码 视图 中 < Body > 与 </Body > 标签 之 间 输 入 如 下 程 
序 代码 。 


<2PHP 
Sconn = 了 MySQL Connect ("LocalHost '，'Ywy'"，"Ywy211") or Die ("数据 连接 错误 !11"); 
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// 连接 数据 库 服务 器 LocalHost, 用 户 名 ywy, 密 码 ywy211 
// 若 连 接 失败 ,提示 数据 连接 错误 并 结束 程序 


MySQL Select DB('RCZP', $conn); // 选择 RCZP 数据库 
$sfzh ="229901199503121538 '; // 定义 PHP 变量 $sfzh 并 为 其 
赋值 


Sres MySQL Query ("Select ypryb lxdh ( $sfzh)", $conn); 
// 调用 MySQL Query 发 送 语句 
Srow MySQL Fetch Row( Sres); ”// 获取 MySQL Query 函数 的 返回 结果 (保存 在 数组 $row 中 ) 


Echo $sfzh." 的 联系 电话 : ". $row[0]; // 输出 结 
MySQL Close ( $conn); // 关闭 数据 库 连接 
3 


(3) 保存 文件 : 单 击 “ 文 件 " 菜 单一 “保存 "选项 ,输入 文件 名 EXP5_25 ,再 单 击 “ 保 
(4) 浏览 页 面 效果 : 单 击 文档 工具 栏 中 “在 浏览 器 中 预览 /调试 "图 标 ( 萎 ) 一 “预览 
在 IExplore” 选 项 ,查看 页 面 效 果 , 如 图 5-12 所 示 。 


(DA 园 htpy/ocalhostw: P - 虽 C 
文件 (9 妨 名 (昌吉 看 (VW) ”收藏 天 (A) 工具 (D。 帮助 (H) 
229901199503121538 的 联系 电话 ，0431-85166032 13988699912 




















图 5-12 在 PHP 中 调用 MySQL 存储 函数 


5.9.2 PHP 调用 存储 过 程 


在 PHP 程序 中 调用 MySQL 存储 过 程 , 除 需 要 调用 函数 MySQL_Query( ) 向 MySQL 发 
送 调用 存储 过 程 的 Call 语句 和 获取 数据 的 Select 语句 外 ,可 能 还 需要 发 送 为 实 参 变量 赋 
值 的 Set 语句 。 

【 例 5.27】 在 PHP 中 调用 RCZP 库 中 的 存储 过 程 gwb_xl_rs, 将 各 岗位 要 求 的 学 历 
人 数 统计 结果 显示 在 页 面 中 。 

(1) 创建 PHP 文件 : 启动 Dreamweaver, 单 击 “ 文 件 "菜单 一 “新 建 " 一 选择 空白 页 中 
文档 类 型 为 “PHP” 一 “确定 "按钮 。 

(2) 输入 PHP 程序 代码 : 在 代码 视图 中 < Body > 与 </Body > 标签 之 间 输 入 如 下 程 
序 代 码 : 


<2?PHP 
Sconn MySQL Connect ('LocalHost', 'ywy', 'ywy211') or die ("数据 连接 错误 !11") ; 
// 连接 数据 库 服务 器 LocalHost, 用 户 名 ywy, 密 码 ywy211 
// 车 连接 失败 则 提示 数据 连接 错误 并 结束 程序 
MYSQL Select DB('RCZP', $conn); // 选择 数据 库 RCZP 
Sres MySQL Query ("Set @zs 0", Sconn) ; // 发 送 为 实 参 全 局 变量 zs 赋值 的 语句 
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Sres MySQL Query("Call gwb xl rs(@zs,@r]l,@r2,@r3,@r4,@r5)", $conn); 
// 发 送 调 用 存储 过 程 的 语句 
Sres MySQL Query ("Select @zs, @r]1,@r2,@r3,@r4,@r5", $conn); 
// 发 送 Select 语句 ,获取 MysQL 变量 
的 值 
Srow -MYSQL Fetch Row( Sres) // 将 结果 保存 于 数组 $row 中 
Echo ' 岗 位 表 中 各 学 历 要 求 的 人 数 统 计 : '.' <br >'; // 分 别 显示 数组 Srow 中 的 内 容 
Echo ' 总 人 数 :'. $row[0] .' <br >', ' 无 学 历 :'. $row[1].'" 人 '.' br >'; 
Echo ' 大 专 :'. $row[2].' 人 '.' <zbr >"',' 本 科 : '. $row[3].'" 人 '.' qbr>'; 
Echo ' 硕 士 : '. $row[4] .' 人 '.' <br >',' 博 士 : '. $row[5] .' 人 '.' zor >'; 
MySQL Close ( $conn); 
多 


(3) 保存 文件 : 单 击 “ 文 件 " 菜 单一 “保存 "选项 ,输入 文件 名 EXP5_26, 青 单 击 “ 保 


(4) 查看 页 面 效 果 : 单 击 文 档 工具 栏 中 “在 浏览 器 中 预览 /调试 "图 标 ( 柄 ) 一 “预览 


在 IExplore” 选 项 ,查看 页 面 效果 ,如 图 5-13 所 示 。 


文件 昌 。 编 加 (E) “二 看 V) ”收藏 夫 A) 工具 0。 帮助) 
岗位 表 中 各 学 历 要 求 的 人 数 统计 ， 
总 人 数 :31 

















图 5-13 PHP 中 调用 MySQL 存储 过 程 


习 题 


一 、 填 空 题 
1. 所 谓 过 程式 数据 库 对 象 就 是 将 _(D_ 作 为 一 种 对 象 存 储 在 服务 器 中 ,在 MySQL 
中 支持 的 过 程式 数据 库 对 象 包括 _@) 、 、@ 和 名 等 内 容 。 





2. MySQL 中 的 复合 语句 用 _Q@ 开始 ,用 _@ 结束 ,中 间 可 以 书写 _@ 条 语句 。 

3. 在 存储 过 程 体 中 使 用 _Q@_ 语句 声明 局 部 变量 ,一 条 声明 语句 可 以 声明 多 个 变 
量 ,但 其 _@@ 及 @ 必须 相同 。 

4. 在 MySQL 过 程 体 中 使 用 关键 字 QD 为 声明 的 局 部 变量 赋值 ,局 部 变量 只 在 
加 _ 有效。 变量 名 的 第 一 个 字母 为 _@) 的 变量 称 为 全 局 变量 ,其 存在 于 整个 会 话 过 
程 中 。 
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5. 在 MySQL 过 程 体 中 获取 表 中 一 行 数 据 可 以 使 用 SELECT 语句 ,结果 保存 在 中 
中 ,其 相应 的 短语 格式 是 ”@ _ ,语句 的 返回 结果 只 能 有 ”@ 行 数据 。 

6. 在 MySQL 过 程 体 中 获取 表 中 多 行 数据 可 以 使 用 Q@ ,其 是 一 个 Select 语句 检索 
出 来 的 _@ ,其 只 能 出 现在 _@ 或 @ 中 。 

7. 声明 游标 的 关键 字 是 “QD _ ,打开 游标 的 语句 是 _@ _, 读 取 游标 中 的 一 行 数据 
使 用 _@ 语句, 关闭 游标 的 语句 是 四 。 

8. MySQL 程序 设计 中 的 分 支 语句 有 ”语句 和 ”@@ 语句 。MySQL 中 的 循环 语 
句 有 国 、@ 和 @ 语句 。 

9. 存储 过 程 是 一 组 为 实现 某 特定 功能 的 _Q@ _ ,实质 是 存放 于 _@ 中 的 程序 对 象 ， 
因此 其 具有 执行 效率 高 减少 网 络 流量 .确保 数据 库 的 安全 性 及 完整 性 等 一 系列 的 优点 。 

10. 调用 存储 过 程 的 语句 是 _Q(D 语句 ,调用 存储 过 程 时 给 出 的 参数 称 为 _@@ 或 
者 _@) _, 其 要 求 与 定义 存储 过 程 时 的 _@ 在 个 数 \ 顺 序 上 一 一 对 应 。 

11. 存储 函数 的 参数 不 需要 方向 说 明 , 即 不 使 用 关键 字 QD 、@ 或 @ 进行 
说 明 。 存 储 函数 需要 使 用 多 语句 说 明 函 数 的 返回 值 类 型 。 

12. 触发 器 是 一 种 与 “中 ”关联 的 数据 库 对 象 , 当 对 一 个 表 的 操作 出 现 特定 的 事件 
时 将 激活 触发 器 ,特定 事件 包括 对 表 中 数据 执行 _@ 、@ 或 由 语句 。 

13. 创建 触发 器 的 命令 动词 是 _ 中 ,其 触发 时 机 的 两 个 关键 字 分 别 是 _@ 四 “和 
_ 国 ,与 触发 器 相关 联 的 表 只 能 是 _ 四 ,不 能 是 如 或 @ 。 

14. 在 MySQL 客户 端 ,查看 一 个 数据 库 已 有 的 触发 器 使 用 的 命令 是 _ 中 ,删除 一 
个 触发 需 使 用 的 命令 是 @ 

15. 事件 是 基于 _ 呈 “触发 执行 某 些 任务 ,其 依靠 MySQL 服务 器 中 的 _@ “功能 模 
块 进行 监控 。 激 活 事件 需要 在 服务 器 端 设置 _@) 参数 为 _@ 或 _ @ ,在 MySQL 配 
置 文件 _@_ 中 设置 参数 Set Global Event_Scheduler = On , 则 每 次 启动 XAMPP 时 自动 启 
动 事件 调度 器 。 





























二 、 单 选 题 
1. 在 MySQL 过 程 体 中 能 正确 定义 变量 的 语句 是 ( ) 。 
A. Declare xl int(5,2) default 10.2 B. Declare xl int(2) ,x2 char(6) 
C. Declare xl as int D. Declare xl ,x2 int(5) default 0 
2. 在 过 程 体 中 为 局 部 变量 赋值 ,下 列 语句 正确 的 是 ( )。 
A l= B. Set 10 =xl 
C. Setxl = 如 ,好 =20 D. xl =10,x2 =20 


3. 在 过 程 体 中 将 YPRYB 表 中 身份 证 号 为 229901199503121538 的 人 员 姓 名 和 移动 
电话 字段 值 保 存 到 已 经 说 明 的 局 部 变量 xm 和 yddh 中 ,下 列 正确 的 语句 是 (  )。 
A. Select 姓 名， 移动 电话 into xm, yddh from ypryb where 身份 证 号 = 
"229901199503121538" 
B. Select 姓名 To xm, 移动 电话 To yddh from ypryb where 身份 证 号 = 
"229901199503121538" 
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C. Select 姓名 Into xm, 移动 电话 Into yddh from ypryb where 身份 证 号 = 


"229901199503121538" 
D. Select 姓名 , 移动 电话 to xm, yddh from ypryb where 身份 证 号 = 
"229901199503121538" 
4. 在 MySQL 过 程 体 中 打开 游标 ypryxx ,正确 的 语句 格式 是 ( js 
A. Use ypryxx B. Create ypryxx C. Open ypryxx D. Fetch ypryxx 
5. 在 存储 过 程 定义 中 , 形 参 方向 选择 为 Out 或 InOut 时 , 实 参 只 能 是 ( ) 。 
A. 常量 B. 变量 C. 表达 式 D. 存储 函数 
6. 有 存储 过 程 gwbtjrs ,其 有 两 个 参数 ,下 列 存储 过 程 调用 正确 的 语句 是 ( 拓 
A. Delimiter gwbtjrs with @nl ,Q@ n2 B. gwbtjrs(@nl,@n2) 
C. Select gwbtjrs(@nl,@n2) D. Call gwbtjrs(@nl,@n2) 
7. 存储 函数 中 的 形 参 不 需要 方向 说 明 , 其 所 有 参数 均 相 当 于 ( ) 。 
A. Out B. In C. InOut D. OutIn 
8. 存储 函数 在 函数 名 后 必须 使 用 语句 ( ) 说 明 函 数 的 返回 值 类 型 。 
A. End < 类 型 说 明 》 B. Return < 表达 式 > 
C. Returns < 类 型 说 明 > D. Function < 类 型 说 明 > 


9. 在 打开 的 RCZP 数据 库 中 删除 存储 函数 ypryb_lxdh ,正确 的 命令 格式 是 ( )。 
A. Drop Procedure ypryb_lxdh 
B. Delete Procedure p7 
C. Drop Function ypryb_lxdh 
D. Delete Function ypryb_lxdh from RCZP 
10. 在 MySQL 中 创建 触发 器 ,用 于 向 表 中 增加 记录 时 检查 数据 的 格式 是 否 正确 , 则 
该 触发 器 的 触发 时 机 应 该 选择 关键 字 ( ” ) 。 
A. Insert B. After C. Trigger D. Before 
11. 删除 RCZP 数据 库 中 的 触发 器 yprybinsert, 正确 的 命令 格式 是 ( }s 
A. Drop Trigger yprybinsert from RCZP 
B. Drop Trigger RCZP. yprybinsert 
C. Delete Trigger yprybinsert from RCZP 
D. Alter Trigger Delete RCZP. yprybinsert 
12. 在 MySQL 配置 文件 my. ini 中 启动 事件 调度 器 ,相关 语句 需要 书写 在 文件 中 


( ) 选项 下 。 
A. [MySQLSERVER] B. [MySQL] 
C. [TRIGGER] D. [mysqld] 
13. 将 MySQL 的 结束 标志 修改 为 $$ ,下 列 语句 正确 的 是 ( )。 
A. Declare $ $ as End B. Set End = $$ 
C. Delimiter $ $ D. Dim $$ 


14. 关于 语句 Alter Event tablel Rename To backupl ;下 列 说 法 正确 的 是 ( js 
A. 语句 用 于 将 tablel 表 的 名 字 修 改 为 backupl 
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B. 语句 用 于 将 tablel 表 复 制 到 backupl 表 中 
C. 语句 用 于 将 tablel 事件 备份 到 backupl 事件 中 
D. 语句 用 于 将 tablel 事件 的 名 字 更 改 为 backupl 


、 多 选 题 


.MySQL 中 支持 的 过 程式 数据 库 对 象 有 ( se 


A. 事件 B. 索引 C. 触发 器 D. 存储 过 程 
E. 存储 函数 F. 属性 





2. MySQL 语句 中 的 注释 格式 有 ( ys 
A. /* */ 注 释 B. -- 注 释 C. + + 注释 D. $$ 注释 
E. # 注 释 F. * 注释 
3. MySQL 的 过 程 体 中 可 以 声明 或 定义 变量 的 语句 有 ( ) 。 
A. Create B. Declare C. New D. Out 
E. Set F. Delimiter 
4. 在 MySQL 过 程 体 中 获取 表 中 数据 ,可 以 使 用 的 语句 有 ( je 
A. Select…Into 语句 B.Create…line 语句 
C. New…Outfile 语句 D.Insert…Into 语句 
E. Case:…When F.Fetch…Into 语句 
5. 在 MySQL 过 程 体 中 常用 的 循环 语句 有 ( ;ss 
A. While B. Case:…When C. Repeat 
D. Loop E. Do:…While 了 .For…Next 
6. 创建 存储 过 程 时 ,说 明 形 参 数据 传递 方向 可 以 使 用 的 关键 字 有 ( ) 。 
A. Int B. Out C. In D. Char 
E. InOut F. Input 
7. 定义 存储 过 程 中 的 形 参 时 方向 说 明 为 In, 则 调用 该 存储 过 程 时 , 实 参 可 以 使 用 的 
形式 有 ( ) 。 


8. 


A. 常量 B. 变量 C. 表达 式 

D. 其 他 存储 过 程 ”E.Repeat 循环 

关于 存储 函数 的 返回 值 ,下 列 说 法 正确 的 是 ( )。 

A. 存储 函数 的 返回 值 通 过 Return 语句 实现 

B. 一 个 存储 函数 的 过 程 体 中 可 以 有 多 个 Return 语句 

C. 一 条 Return 语句 最 多 可 以 返回 7 个 结果 量 

D. 若 一 个 存储 函数 需要 返回 不 同类 型 的 数据 , 则 可 以 在 过 程 体 中 设置 多 个 
Return 语句 实现 

E.Return 语句 的 返回 值 类 型 必须 与 存储 函数 Returns 说 明 的 类 型 相 一 致 


. 在 PHPMyAdmin 主页 中 查看 数据 库 中 的 存储 函数 ,下 列 说 法 正确 的 是 ( jia 


A. 首先 应 该 单 击 选 定 PHPMyAdmin 主页 导航 面板 中 的 数据 库 
BB: 可 以 在 “SQL” 选项 卡 中 输入 “Show Function Status” 语 句 查 看 存储 函数 名 称 
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C. 可 以 在 “SQL "选项 卡 中 输入 "Show Create Function < 存储 函数 名 > "语句 查看 
存储 函数 的 创建 语句 
D. 可 以 在 “设计 器 "选项 卡 中 修改 数据 库 中 的 存储 函数 
E. 可 以 单 击 “ 程 序 " 选 项 卡 查 看 连接 数据 库 中 的 存储 函数 及 存储 过 程 
10. 能 够 激活 数据 库 中 触发 器 的 语句 有 ( )。 
A. Select 语句 B. Insert 语句 C. Create 语句 D. Update 语句 
E. Delete 语句 下. Drop 语句 
11. 在 MySQL 配置 文件 my. ini 中 启动 事件 调度 器 ,其 可 以 使 用 的 语句 有 ( je 
A. Event_Scheduler =1 B. Event_Scheduler = On 
C. Default_Character_Set = utf8 D. default_character_set = On 
E. Set Global Event_Scheduler = On 
12. 在 MySQL 中 命令 行 客户 端 执 行 Use RCZP; 语 句 后 执行 如 下 语句 ,下 列 说 明 中 正 
确 的 有 ( 着 


Create Event If Not Exists bfsj On Schedule Every 10 Seconds 
Do Insert Into bfl (name) Values ('abc'); 


A. 语句 创建 了 一 个 名 为 bfsj 的 事件 

. 创建 的 事件 保存 在 RCZP 数据 库 中 

. 事件 10 秒 后 启动 ,运行 后 自动 删除 事件 
. 事件 向 bfl 表 中 增加 一 条 纪录 

. 若 bfsj 已 经 存在 , 则 创建 命令 出 错 

F. 事件 指定 的 时 间 间 隔 是 10 秒 


、 程 序 填空 题 


1. 在 MySQL 客户 端 创建 一 个 存储 过 程 ypryb_cls_mm ,用 于 清除 给 定 身份 证 号 对 应 
人 员 的 密码 。 


Use RCZP; 
中 $$ 


Create ©® ypryb cls mrm(in sfzh char(18)) 
Begin 
加 ypryb Set 密码 ='' Where 身份 证 号 =sfzh 
End $$ 


2. 在 MySQL 客户 端 中 设计 存储 函数 Found_Name, 用 于 查询 给 定 的 名 字 在 ypryb 表 
中 出 现 的 次 数 。 
Create “四 ”found name ( zm Varchar (10)) ©®@ 
Return (select count (姓名 ) From RCZP.ypryb Where @@ ); 
3. 设计 触发 器 YPRYB_insert。 当 每 次 向 RCZP 库 中 YPRYB 表 插入 一 条 记录 后 ,用 
户 变 量 @ countrs 的 值 增 1。 


国 台 人 轩 
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Create @D RCZP.YPRYB insert ” @ Insert OnRCZP.YPRYB ® 
Set@ countrs= @ ; 


4. 设计 Insert_1Week 事件 。 从 现在 起 ,每 周 自动 向 Logfile 表 的 logtime 字段 插入 当 
前 日 期 ,直到 2030 年 12 月 31 日 截止 。 
Create Event If Not Exists Insert 1Week 人 Every 1 Week 


©®@ curdate () Ends '2030 12 31" 
@ Insert Into logfile (logtime) values (curdate () ) 





1， 如 何 绘 制程 序 控 制 结构 的 流程 图 ? 在 MySQL 存储 过 程 题 中 有 哪些 流程 控制 
语句 ? 

2. 什么 是 游标 ? 在 存储 过 程 中 读 取 游标 数据 的 操作 流程 是 什么 ? 

3. 存储 过 程 和 存储 函数 有 哪些 相同 点 及 不 同 点 ? 如 何 查看 数据 库 中 定义 的 存储 过 
程 或 存储 函数 ? 

4. 如 何 创建 触发 器 ?哪些 SQL 语句 能 够 激活 触发 器 ? 

5. 什么 是 事件 ?事件 与 触发 器 有 哪些 区 别 ? 
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Dreamweaver 及 静态 网 页 设计 基础 


HTML 是 一 种 网 页 设计 描述 性 的 标记 语言 ,用 于 描述 网 页 内 容 的 显示 方式 和 结构 。 
例如 ,在 网 页 中 定义 标题 .文本 或 表格 等 。Dreamweaver( 简称 DW ) 是 一 款 集 网 页 设计 和 
网 站 管理 于 一 身 的 所 见 即 所 得 的 网 页 设计 软件 ,通过 可 视 化 操作 可 以 设计 网 页 ,由 系统 生 
成 HTML 和 PHP 程序 代码 。 设 计 网 页 主要 解决 下 列 问题 : 

(1) 如 何 安装 与 配置 Dreamweaver 软件 ? 

(2) 如 何 创建 和 管理 站 点 ? 

(3) HTML 包括 哪些 基本 元 素 及 各 自 的 作用 ? HTML 文档 的 基本 结构 是 什么 ? 

(4) 如 何 设 计 网 页 中 的 文本 、 图 像 链接 和 水 平 线 等 对 象 ? 

(5) CSS 的 作用 是 什么 ”如 何 创建 CSS? 


6.1 Dreamweaver 软件 的 安装 与 配置 


在 设计 网 站 和 网 页 之 前 ,应 该 下 载 和 安装 相关 的 软件 开发 工具 。 有 很 多 可 供 开 发 网 
站 和 网 页 的 软件 工具 ,Dreamweaver 仅 是 其 中 一 种 。 在 软件 开发 工具 安装 后 ,通常 还 要 按 
实际 需求 或 个 人 习惯 配置 系统 环境 。 


6.1.1 Dreamweaver 系统 的 安装 和 启动 


1. Dreamweaver CS5S 的 安装 


安装 的 具体 操作 步骤 如 下 : 

(1) 双击 Dreamweaver CS5 的 安装 文件 压缩 包 , 系 统 自动 解压 缩 并 安装 ,首先 出 现 
“欢迎 使 用 "界面 。 

(2) 单 击 “ 接 受 "按钮 ,在 “序列 号 "界面 中 ,正确 输入 软件 的 序列 号 ,选择 语言 。 

(3) 单 击 “ 下 一 步 "按钮 ,在 Adobe ID 界面 中 ,需要 创建 Adobe ID ,或 使 用 已 经 注册 成 
功 的 Adobe ID。 


(4) 单 击 “ 下 一 步 " 按 钮 ,在 “安装 选项 "界面 中 (如 图 6-1 所 示 ) 选 择 安装 软件 的 组 
件 , 设 置 软件 的 安装 位 置 。 





\ Adobe Dreanveaver C55 


v 所 有 组 件 


国 ADOBE DREAMWEAVER CS5 304 MB 二 ADOBE DREAMWEAVER CS5 


所 列 SS 

Adobe ID 安装 总 大 小 : 781 MB 
选项 

安村 





图 6-1 “安装 选项 "界面 


(5) 单 击 * 安 装 "按钮 ,开始 安装 软件 ,并 在 * 安装 进度 "界面 中 显示 进度 。 
(6) 单 击 “完成 "按钮 ,安装 完毕 。 


2. Dreamweaver CS5 的 启动 


单 击 “ 程 序 " 菜 单一 “所 有 程序 ”一 Adobe Dreamweaver CS5 选项 ,Dreamweaver CS5 的 
开始 界面 如 图 6-2 所 示 。 


最 近 打 开 的 文档 新 建文 档 类 型 
| 


















































打开 最 近 的 项 目 新 建 主要 功能 

二 bbsffonn html 图 HTML a CSS 术 查 模式 
里 wssdBG html 里 coldFusion 

午 bbsiarphp 周 PHP ES ee 
二 bbabgphp 二 ASP VBseript 中 aa 关 文件 
叶 bbs/YPRYZC html 二 xsLT( 整 页 ) 

I 出 二 | 3s 过 
叶 bbsiKPFHTML 轿 Javascript 图 :| BmowserLab 集成 
号 bbsiexhtml 二 xML Ds 

国 bbs/YPRYZCPHP 而 Dreamweaver 站 点 

巴 打开 Ds. 

加 快 加 和 AITw 

罩 新 产能 > Dw 

四 资源 > 

国 Dreamweaver Exharegs > 





图 6-2 Dreamweaver CS5 的 开始 界面 
开始 界面 集中 呈现 的 常用 操作 如 下 : 
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(1) 单 击 “ 打 开 最 近 的 项 目 ” 窗 格 中 的 文档 ,可 以 打开 对 应 的 文档 。 单 击 “ 打 开 ” 按 
钮 ,可 以 打开 其 他 网 页 文档 。 

(2) 单 击 “ 新 建 " 窗 格 中 的 某 种 类 型 ,可 以 创建 新 文档 或 站 点 。 

(3) 单 击 Dreamweaver Exchange 按钮 ,可 以 打开 官方 网 站 下 载 所 需要 的 扩展 插件 。 


6.1.2 Dreamweaver 系统 环境 的 配置 


由 于 不 同 用 户 或 应 用 程序 对 系统 环境 要 求 可 能 不 同 ,因此 ,进入 系统 后 ,有 时 需要 对 
系统 环境 进行 配置 ,以 满足 个 性 化 的 要 求 。 单 击 “ 编 辑 " 菜 单一 “首选 参数 "选项 ,在 “首选 
参数 "对 话 框 中 ,可 以 配置 系统 环境 ,如 图 6-3 所 示 。 


首选 才 数 


总 


yy] | 
5m 兰 


文档 选项 : 回 显示 欢迎 屏 夏 G) 

口 局 动 时 重新 打开 文档 @) 

回 打开 只 读 文件 时 警告 用 户 gg) 

局 用 相关 文人 
搜索 动态 相关 文件 中 ); | 手动 ” 国 | 

移动 文件 时 更 新 链接 | 提示 国 | 

插入 对 象 时 显示 对 话 框 ) 

回 区 许 双 字 节 内 联 输 入 @) 

回 标题 后 切换 到 | 兽 通 段落 4) 

口 区 许多 个 连续 的 空格 虽 ) 

回 用 《strong》 和 <en> 代 苦 @> 和 <i>0D 

参数 分 类 回 在 @y 或 Qi)-Q6》 标签 中 放置 可 编辑 区 域 时 发 出 区 省 


历史 步 邓 最 多 次 数 U: [50 
拼写 字 奥 G) 可 
ET CC 下 


配置 参数 


过 过 册 降 学 二 洁 央 基本 二 二 二 ?| 避 | 
引 
































图 6-3 “首选 参数 "对 话 框 


1.“ 常 规 ” 分 类 


(1) 选中 “显示 欢迎 屏幕 "项 ,启动 Dreamweaver 后 ,打开 文档 前 ,显示 欢迎 屏幕 。 

(2) 选中 “启动 时 重新 打开 文档 "项 ,启动 系统 时 自动 打开 上 次 退出 系统 时 处 于 打开 
状态 的 文档 。 

(3)“ 移 动 文件 时 更 新 链接 "用 于 设置 移动 更 名 或 删除 文档 时 是 否 自动 更 新 链接 。 

(4) 选中 “允许 多 个 连续 的 空格 "项 ,在 HTML 文档 中 输入 多 个 连续 空格 时 ,浏览 器 
也 显示 多 个 空格 (默认 情况 下 浏览 器 将 多 个 连续 空格 只 显示 1 个 ) 。 

(5)“ 历 史 步 又 最 多 次 数 "项 ,设置 在 “历史 记录 "面板 中 保留 和 显示 的 步骤 数 。 


2.“ 新 建文 档 ” 分 类 


(1)“ 默 认 文 档 " 项 ,设置 新 建 网 页 的 文档 类 型 ,如 HTML .CSS 和 PHP 等 。 
(2)“ 默 认 扩展 名 ”项 ,为 新 建 的 HTML 页 面 指定 文件 扩展 名 为 htm 或 html, 此 选项 
只 对 HTML 文件 类 型 可 用 。 
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(3)“ 默 认 文档 类 型 "项 ,设置 XHTML 规范 类 型 ,使 HTML 文档 符合 XHTML 规范 。 
(4)“ 默 认 编码 "项 ,指定 创建 新 页 面 采用 的 默认 编码 (字符 集 ) 。 


6.2 站 点 及 其 设计 与 管理 


设计 网 页 的 最 终 目 的 是 设计 一 个 完整 的 网 站 。 因 此 ,在 设计 网 页 之 前 ,应 该 首先 在 本 
地 计算 机 上 模拟 网 站 创建 本 地 站 点 ,以 便 规划 网 站 结构 ,管理 网 站 。 


6.2.1 站 点 的 基础 知识 


1. 站 点 的 概念 


站 点 是 开发 及 建设 网 站 的 环境 ,用 于 存储 网 站 开发 阶段 的 文件 夹 ( 目录) 及 其 相关 资 
源 文件 。 文 件 夹 由 主 目录 和 若干 个 子 目录 构成 ,每 个 目录 用 于 存储 网 页 (HTML) ,程序 脚 
本 (PHP) ,图像 和 样式 (CSS) 等 网 站 的 资源 文件 。 


2. 文件 夹 类 型 


一 个 站 点 可 以 设置 本 地 和 服务 器 (远程 ) 两 个 文件 夹 。 

(1) 本 地 文件 夹 可 以 是 网 页 设计 者 计算 机 上 任何 位 置 的 文件 夹 ,如 D:\RCZP。 当 
然 , 也 可 以 设置 在 …\XAMPP\HTDOCS\ 下 ,如 …\XAMPP\HTDOCS\RCZP。 本 地 文件 夹 是 
网 页 设计 者 的 工作 主 目录 ,用 于 存储 分 类 文件 夹 、 网 页 ,程序 脚本 及 其 相关 的 资源 文件 。 
如 果 仅 设计 调试 或 浏览 静态 网 页 , 则 只 需要 本 地 文件 夹 。 

(2) 远程 文件 夹 位 于 Web 服务 器 上 ,也 称 服务 器 文件 夹 , 是 浏览 网 页 时 的 资源 文件 
目录 。 远 程 文件 夹 ( 主 目录 ) 通 常 与 本 地 文件 夹 ( 主 目录 ) 同 名 ,并 且 具 有 相同 的 目录 结 
构 ,便于 资源 文件 上 传 和 维护 。 在 设计 和 调试 动态 网 页 (PHP) ,发布 网 页 之 前 ,需要 为 站 
点 设置 服务 器 文件 夹 。 在 设计 .调试 和 浏览 动态 网 页 阶段 ,也 可 以 将 服务 器 文件 夹 设 置 在 
网 页 设计 者 计算 机 的 …\XAMPP\HTDOCS\ 文 件 夹 下 ,如 …\XAMPP\HTDOCS\RCZP。 


6.2.2 建立 本 地 站 点 


通常 先 创建 站 点 ,然后 再 设置 对 应 的 服务 器 及 其 文件 来。 创建 站 点 的 步骤 如 下 : 

(1) 在 本 地 磁盘 上 创建 文件 夹 作为 站 点 文件 夹 ( 主 目 录 ) ,如 D:\RCZP, 并 在 该 文件 
夹 中 创建 相关 的 资源 文件 夹 ,如 Image 和 CSS 等 。 

(2) 在 Web 服务 器 计算 机 上 创建 服务 器 文件 夹 ,例如 ,在 XAMPP 的 默认 安装 目录 
下 ,创建 …\XAMPP\HTDOCS\RCZP。 

(3) 单 击 “ 站 点 "菜单 一 “新 建站 点 "选项 ,弹出 “站 点 设置 对 象 " 对 话 框 ,如 图 64 
所 示 。 
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6-4 ”站 点 设置 对 象 一 一 站 点 选项 卡 


(4) 输入 “站 点 名 称 ” ,如 RCZP, 此 名 称 将 显示 在 “文件 "面板 和 “管理 站 点 "对 话 框 
中 。 在 “本 地 站 点 文件 夹 "文本 框 中 选择 或 输入 站 点 文件 夹 名 称 ,如 D:\RCZP\。 

(5) 在 站 点 设置 对 象 一 一 服务 器 选项 卡 中 , 单 击 “ 服 务 器 "一 ”+ ”按钮 ,在 “基本 " 选 
项 卡 中 添加 信息 ,如 图 6-5 所 示 。 





图 6-5 服务 器 的 “基本 "选项 卡 
(6) 在 服务 器 的 “高 级 "选项 卡 中 ,选择 服务 器 模型 等 信息 ,如 图 6-6 所 示 。 





图 6-6 服务 器 的 “高 级 "选项 卡 


上 传 本 地 文件 到 服务 器 有 两 种 方式 : 一 种 是 设计 完 网 页 一 次 性 上 传 ; 另 一 种 是 选中 
服务 器 “高 级 "选项 卡 的 “保存 时 自动 将 文件 上 传 到 服务 器 ”。 
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(7) 单 击 “ 保 存 " 按 钮 后 ,返回 “站 点 设置 对 象 " 对 话 框 ,添加 了 一 个 服务 器 ,如 图 6-7 
所 示 , 选 中 “远程 "和 “测试 " 复 选 框 。 


站 点 设置 对 象 RCZPSERYER 


您 将 在 此 位 置 选择 承载 人 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (SP) 或 Web 管理 员 


烷 店 ; 要 下 姑 环 Dreamweaver 区 点 上 工作 ， 傅 无 请 完成 氏 牙 需 。 血 轩 要 道光 车 Web 玫 恬 
布 页 坝 ， 低 只 再 启 六 一 个 运 杏 昕 务 避 8 可 - 
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图 6-7 站 点 设置 对 象 一 一 服务 器 选项 卡 


(8) 选中 服务 器 (如 RCZPSERVER ) 行 后 , 单 击 “编辑 现 有 服务 器 " ( 笔 图 标 ) 按 钮 ,可 
以 重新 修改 服务 器 信息 ; 单 击 “ 删 除 服务 器 ”( 减 号 图 标 ) 按钮 将 删除 服务 器 信息 。 

(9) 展开 * 站 点 设置 对 象 "对 话 框 中 的 “高 级 设置 "选项 ,选择 “本 地 信息 "选项 ,设置 
默认 图 像 文件 夹 ,如 D:\RCZP\Image。 

(10) 单 击 “保存 "按钮 ,完成 设置 一 个 站 点 ,如 RCZP。 在 “文件 ”面板 中 将 展现 站 点 
文件 . 子 文件 夹 及 其 相关 文件 ,如 图 6-8 所 示 。 


6.2.3 管理 站 点 


建立 站 点 后 ,需要 对 各 个 站 点 进行 管理 ,如 打开 、 编 辑 .切换 ,删除 和 复制 站 点 等 。 
1. 选择 当前 站 点 


在 保存 网 页 文件 时 ,系统 默认 目录 为 当前 站 点 的 本 地 文件 夹 。 可 以 从 “文件 "面板 的 
下 拉 列 表 框 中 选择 站 点 名 称 ,切换 当前 站 点 ,如 图 6-9 所 示 。 
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图 6-8 用 记事 本 编辑 HTML 图 6-9 选择 当前 站 点 的 “文件 "面板 
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2. 编辑 站 点 


编辑 站 点 的 具体 操作 步骤 如 下 : 

(1) 单 击 “ 站 点 "菜单 一 “管理 站 点 "选项 ,在 “管理 站 点 ”对 话 框 中 ,如 图 6-10 所 示 ， 
选中 站 点 名 称 , 单 击 “ 编 辑 " 按 钮 ,或 者 双击 站 点 名 称 
(如 RCZP)。 





PHP Test Site 
bbs 


(2) 在 “站 点 设置 对 象 ”对 话 框 的 “站 点 "选项 卡 | Eee 


wssd 











中 (如 图 6-4 所 示 ) 可 以 修改 站 点 信息 ;在 “服务 器 " 选 
项 卡 中 (如 图 6-7 所 示 ) ,双击 服务 器 行 ,或 者 单 击 * 编 
辑 现 有 服务 器 "按钮 ,可 以 调整 服务 器 的 信息 ( 含 服务 
































器 文件 夹 ) 。 - 
(3) 单 击 * 保 存 "按钮 ,返回 "管理 站 点 "对 话 框 ，[ 上 于 天 
最 后 单 击 “ 完 成 "按钮 。 图 6-10 “管理 站 点 "对 话 框 


3. 复制 站 点 


通过 复制 站 点 可 以 创建 多 个 结构 相同 的 站 点 。 在 “管理 站 点 "对 话 框 中 选中 站 点 名 ， 
单 击 “ 复 制 "按钮 ,新 复制 的 站 点 名 称 为 * 源 名 + 复制 ” ,与 源 站 点 具有 相同 的 文件 夹 。 


4. 删除 站 点 


删除 站 点 只 是 删除 Dreamweaver 同 本 地 站 点 间 的 关系 ,并 不 删除 文件 和 文件 夹 。 在 
“管理 站 点 ”对话 框 中 ,选中 要 删除 的 站 点 名 称 , 单 击 “删除 "按钮, 即 可 删除 站 点 。 


6.3 Dreamweaver 基本 操作 


Dreamweaver 是 设计 网 页 的 一 种 可 视 化 向 导 , 在 向 导 的 引导 下 ,通过 键盘 或 鼠标 操作 
菜单 .对话 框 或 控制 面板 等 可 视 化 对 象 ,可 以 生成 HTML 代码 ,协助 用 户 设计 网 页 。 


6.3.1 工作 界面 


工作 界面 由 工作 模式 下 拉 框 .菜单 栏 文档 工具 栏 文档 窗口 ,状态 栏 .属性 面板 和 浮 
动 面 板 组 等 部 分 组 成 ,如 图 6-11 所 示 。 
1. 工作 区 布局 选择 


工作 区 布局 是 系统 工作 界面 及 各 种 面板 的 一 种 布局 方式 ,选择 工作 布局 以 便 适 应 个 
性 化 要 求 。 系 统 默认 是 “设计 器 "工作 区 布局 ,可 以 从 工作 区 布局 下 拉 框 中 选择 其 他 工作 
区 布局 ,如 应 用 程序 开发 人 员 ,经 典 或 双重 屏幕 等 ,进行 工作 区 布局 切换 。 
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菜单 栏 文档 工具 栏 工作 区 布局 下 拉 框 
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图 6-11 Dreamweaver 的 工作 界面 


2. 菜单 栏 


菜单 栏 用 于 显示 菜单 项 ,主要 包括 文件 编辑、 查看 \ 插 入、 修改 、 格 式 \ 命 令 \ 站 点 、 窗 
口 和 帮助 菜单 项 。 单 击 某 菜单 项 ,可 执行 对 应 的 操作 。 


3. 文档 工具 栏 


文档 工具 栏 包 含 编辑 文档 的 常用 操作 按钮 ,如 代码 , 拆 分 和 设计 等 。 使 用 这 些 按钮 可 
以 快速 切换 文档 的 视图 模式 ,还 可 以 预览 /调试 网 页 和 设置 网 页 标题 等 。 


4. 文档 窗口 


文档 窗口 用 于 显示 当前 文件 内 容 。 窗 口 顶部 的 选项 卡 显示 所 有 打开 的 文件 名 , 若 修 
改 文件 内 容 尚未 保存 , 则 文件 名 后 显示 一 个 星 号 。 文 档 窗口 中 有 如 下 3 种 视图 方式 。 

(1) 代码 视图 : 用 于 编辑 HTML ,JavaScript ,程序 脚本 代码 ( 如 PHP) 以 及 任何 其 他 类 
型 的 代码 。 在 代码 视图 中 可 以 查看 、 修 改 和 编写 网 页 代码 。 在 输入 HTML 代码 的 过 程 
中 ,可 以 采用 代码 引导 功能 选择 标签 及 其 属性 ,例如 ,输入 ”< "后 可 以 从 下 拉 列 表 框 中 选 
择 标签 名 (如 了) ; 按 空格 键 后 ,从 下 拉 列 表 框 中 选择 属性 名 (如 align) ,再 进一步 输入 或 选 
择 属 性 值 (如 left) ,如 图 6-12 所 示 。 

(2) 设计 视图 : 用 于 可 视 化 页 面 布局 ,直接 输入 网 页 中 的 内 容 , 以 可 视 化 形式 呈现 ， 
类 似 于 浏览 器 的 风格 ,以 所 见 即 所 得 的 方式 显示 和 编辑 网 页 的 内 容 。 

(3) 拆 分 视图 : 将 窗 格 分 为 左右 两 个 部 分 , 左 窗 格 是 代码 视图 , 右 窗 格 是 设计 视图 。 
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(0D) 


<meta http-equiv="Content-Type” content= 
“text/html; charset=utf-8”/> 
《title》 无 标题 文档 《ftitle> 

</head> 

<body> 

<p align= 

《/body> 

</html> 


司 
区 
区 
甘 
清 
人 

> 














图 6-12 输入 标签 及 属性 的 代码 引导 下 拉 框 


单 击 设计 窗 格 中 的 内 容 , 可 以 定位 代码 窗 格 中 的 代码 ,便于 查阅 和 修改 网 页 的 代码 。 


5. 状态 栏 
状态 栏 显示 当前 文档 的 相关 信息 ,如 当前 标签 名 称 和 信息 缩放 百分比 等 。 
6. 属性 面板 


属性 面板 又 称 属性 检查 器 。 单 击 “ 窗 口 "菜单 一 “属性 "选项 打开 属性 面板 ,其 内 容 与 
当前 选中 元 素 有 关 。 例 如 ,选中 图 像 ,将 显示 图 像 的 文件 路 径 、 宽 度 和 高 度 等 。 


7. 浮动 面板 组 


工作 界面 有 许多 功能 小 窗口 (面板 ) ,所 在 位 置 不 确定 ,通过 鼠标 可 以 拖 动 改变 位 置 ， 
所 以 通常 称 为 浮动 面板 。 系 统 默认 显示 插入 、CSS 和 文件 面板 等 , 单 击 “ 窗 口 "菜单 可 以 
打开 其 他 面板 。 


6.3.2 设计 网 页 的 一 般 步 又 


1. 新 建 网 页 


(1) 单 击 “ 开 始 " 菜 单一 “所 有 程序 ”一 Adobe Dreamweaver CS5 选项 。 
(2) 在 开始 页 , 单 击 “ 新 建 "列表 中 的 HTML 选项 ,打开 工作 界面 并 新 建 网 页 文档 。 


2. 编辑 和 保存 网 页 

(1) 单 击 文档 编辑 区 ,输入 网 页 中 的 内 容 , 如 “欢迎 访问 人 才 招 聘 网 !”。 

(2) 单 击 “ 文 件 " 菜 单一 “保存 "选项 ,在 “另存 为 "对 话 框 中 选择 文件 路 径 ,并 为 文件 
命名 ,如 Index. HTML, 单 击 “ 保 存 " 按 钮 ,保存 文件 。 

3. 预览 网 页 

单 击 文 档 工具 栏 中 的 “在 浏览 器 中 预览 /调试 "按钮 ,选择 “预览 在 [Explore” 选项 , 预 
览 网 页 。 另 外 ,也 可 以 按 F12 键 或 者 单 击 “ 文 件 " 菜 单一 “在 浏览 器 中 预览 "一 IExplore 选 
项 ,预览 网 页 。 


人 @ 为 。 基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


6.4 HTML 文档 的 设计 基础 


HTML 文档 (文件 ) 是 由 标签 (也 称 标记 ) 符号 定义 的 各 元 素 组 成 的 , 即 网 页 是 由 
HTML 标签 进行 描述 的 。 网 页 与 HTML 文档 是 同一 概念 的 两 种 不 同 表 现形 式 : 用 HTML 
编写 的 代码 文件 称 为 HTML 文档 ,而 HTML 文档 通过 浏览 器 展现 出 来 的 页 面 效 果 称 为 
网 页 。 


6.4.1 HTML 基本 术语 


HTML 文档 由 诸多 元 素 组 成 ,每 个 元 素 由 标签 或 标签 对 及 其 属性 构成 ,各 种 标签 有 各 
自 的 属性 和 作用 。 


1. 标签 


标签 是 HTML 中 一 些 有 特定 意义 的 符号 , 它 决 定 着 网 页 的 效果 和 布局 。 标 签 都 括 在 
一 对 尖 括 号 < 和 > 中。 可 分 为 对 标签 和 单 标签 。 

(1) 对 标签 。 由 起 始 和 结束 标签 组 成 ,起 始 标签 一 般 用 ”< 标签 名 称 > ”表示 ,而 结 
东 标 签 用 * < /标签 名 称 > "表示 ,中 间 是 受 标签 控制 或 修饰 的 内 容 。 例 如 , <B > 网 页 程 
序 设计 </B > ,其 中 <B > 是 起 始 标签 , </B > 是 结束 标签 ,功能 是 以 粗 体 显 示 “ 网 页 程序 
设计 ”。 

(2) 单 标签 。 只 有 起 始 标签 ,不 包含 任何 内 容 , 往 往 只 完成 一 个 功能 或 操作 。 一 般 在 
标签 首部 或 尾部 加 斜 杜 / ,如 <Br/ > 和 </Br> 均 表示 换行 符 。 

2. 元 素 

元 素 一 般 由 对 标签 .属性 以 及 标签 之 间 的 内 容 构成 ,浏览 器 依据 标签 的 作用 解析 各 个 
元 素 。 例 如 , < Title > 我 的 第 一 个 网 页 </Title > 描述 网 页 的 标题 ,由 < Title > 开始 ，</ 
Title > 结束 ,元 素 内 容 是 “我 的 第 一 个 网 页 ” 。 

有 些 元 素 只 包含 起 始 标签 及 其 属性 ,例如 , < IMG SRC = "LOGO. JPG" Width ="50" 

Height ="50"/ > 。 
3. 标签 属性 


多 数 标签 具有 属性 ,每 种 标签 的 多 个 属性 之 间 没 有 前 后 顺序 关系 ,用 空格 隔 开 即 可 。 
属性 包括 名 和 值 , 属 性 值 必须 在 元 素 的 起 始 标签 中 定义 ,通常 包含 在 半角 双 引 号 中 。 
标签 格式 : 


标签 名 称 属性 名 1 一 值 1" 属性 名 2 一 值 2"…… > 
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二 


C&9 


HTML 元 素 的 完整 结构 如 图 6-13 所 示 。 如 果 属 属性 
性 代码 中 出 现 引号 嵌 套 , 则 外 层 用 单 引号 ( 7 ,内 层 








用 双 引 号 ( 入 ) i iid Algn- ”Center > 第 一 级 标题 WH1> 
起 始 标 签 元 素 内 容 结束 标签 
6.4.2 ”HTML 文档 的 设计 工具 ee 
及 规则 图 6-13 ”HTML 元 素 结构 图 


一 个 网 页 对 应 一 个 HTML 文档 ,文档 的 扩展 名 为 HTM 或 HTML, 内容 是 纯 文本 , 因 
此 ,可 以 使 用 任何 能 编辑 纯 文本 的 软件 编写 HTML 文档 。 

1. 用 记事 本 编写 HTML 文档 

在 设计 HTML 文档 的 过 程 中 ,首先 要 用 编辑 器 新 建 HTML 文件 ,编写 HTML 代码 , 保 
存 文 件 之 后 ,才能 浏览 网 页 效果 。 

【 例 6.1】 新 建 网 页 文件 Onepage. HTML ,浏览 效果 如 图 6-14 所 示 。 

在 记事 本 中 输入 代码 ,如 图 6-15 所 示 , 单 击 “ 文 件 "菜单 一 “保存 "选项 , “保存 类 型 ” 
选择 “所 有 文件 " ,输入 文件 名 为 Onepage. HTML, 单 击 “ 保 存 " 按 钮 。 


外 新 建 文本 文档 . html - 记事 本 


= <Title> 我 的 第 一 个 网 页 </Title> 
BE: md [ed </Head> 


文件 (E) 编辑 人 E) 查看 (V) 收藏 ”以 <Body> 


Hello, HTML! Hello,HTML! 
</Body> 
<Html> 


图 6-14 页 面 浏览 效果 图 6-15 记事 本 编辑 HTML 代码 





2. 设计 HTML 文档 


在 开始 页 面 , 单 击 “ 文 件 "菜单 一 “新 建 "选项 ,在 “新 建文 档 " 对 话 框 中 ,选择 页 面 类 
型 为 “空白 页 "和 HTML ,布局 为 “无 ”, 单 击 “ 创 建 " 按 钮 ,新 建 一 个 空白 文件 。 切 换 到 “ 代 
码 " 视 图 ,如 图 6-16 所 示 。 

将 <Tite > 和 </Tite > 标签 之 间 的 文字 “无 标题 文档 "修改 为 “我 的 第 一 个 网 
页 ” ,在 <Body > 和 </Body > 标签 之 间 输 入 “Hello, HTML!”。 单 击 “ 文 件 " 菜 单一 
“保存 "选项 ,在 “另存 为 "对 话 框 中 ,输入 文件 名 Onepage 和 存放 位 置 , 按 F12 键 济 
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<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 
Transitional//EN" 
"http://www-.w3.0rg/TR/xhtml1/DTD/xhtmli-transiti 
onal.dtd"> 

<html xmlns="http://www-w3.org/1999/xhtml"> 
<head> 

<meta http-equiv="Content-Type" content= 
"text/html; charset=utf-8" /> 
<title> 无 标题 文档 </title> 

</head> 














<body| 
BB czr 下 本 地 视图 “加 1608 
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图 6-16 “代码 "视图 


览 网 页 。 

从 图 6-16 可 以 看 出 ,新 建 HTML 文档 后 ,系统 自动 产生 若干 行 代码 ,典型 的 标签 含义 
如 下 : 

(1) < 1 DOCTYPE html … > ,用 于 声明 文档 类 型 ,不 是 HTML 标签 ,必须 写 在 
HTML 文档 的 第 一 行 , 位 于 < Html > 标签 之 前 。 如 果 网 页 文档 中 没有 < ! DOCTYPE 
> , 则 浏览 器 按 默认 的 文档 类 型 解析 网 页 ,各 种 浏览 器 可 能 有 不 同 的 浏览 效果 。 

(2) < Html xmlns ="http://www. w3. org/1999/xhtml" > ,说 明 整 个 网 页 标签 应 该 符 
合 XHTML 的 规范 。 

(3) < meta http-equiv =" Content-Type" content =" text/html; charset = utf-8" / >, 
其 中 < meta > 标签 可 提供 有 关 页 面 的 元 信息 ( meta-information ) , 如 搜索 引擎 的 关键 字 。 
< meta > 标签 位 于 <head > … </head > 内 ,没有 结束 标签 。 http-equiv = " Content-Type" 
表示 描述 文档 类 型 ,content = "text/html" 表示 浏览 器 要 解析 HTML 文档 ;"charset = utf-8" 
表示 文档 内 容 采 用 utf-8 字符 编码 ,中 文 网 页 通常 采用 GB2312 或 utf-8 编码 。 

互联 网 搜索 引擎 将 查找 < meta > 元 素 中 定义 的 关键 字 。 例 如 ,在 设计 网 页 时 ,编写 < 
meta name = "keywords"” content =" 人 才 招 聘 , 用 人 岗位 , MySQL" > 代码 ,在 互联 网 搜索 引 
人 擎 界面 中 输入 ”人才 招 聘 “ 用 人 岗位 ?或 “MySQL ”关键 字 ,都 能 搜索 到 该 网 页 。 


3. HTML 的 书写 规范 
(1) HTML 文件 的 列 宽 不 受 限制 ,多 个 标签 可 写成 一 行 。 
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(2) 标签 中 的 某 些 项 不 能 分 行 写 。 例 如 ,下 列 代码 中 将 Tiue 分 两 行 是 错误 的 。 


<Ti 
tle SHello, HIML! </Title > 


(3) 尖 括 号 ,标签 和 属性 名 等 必须 用 半角 字符 。 
6.4.3 HTML 文档 基本 结构 


通过 例题 6. 1 可 以 看 出 ,一 个 HTML 文档 至 少 要 包括 四 对 标签 ,各 对 标签 及 顺序 如 图 
6-17 所 示 。 

(1) < Huml > 结构 标签 。 通 常 处 于 文档 的 最 前 面 , 表 mi 
示 文 档 开始 , 即 浏览 器 从 < Html > 开始 解析 网 页 ,直至 遇 。。 标题 开始 
到 </Html > 为 止 ,因此 , < Html > … </Html > 标识 了 标题 结束 
HTML 文件 的 开始 和 结束 ,所 有 其 他 标签 都 包含 在 < Html 头 部 结束 
> 和 </Html > 之 间 。 主体 开始 

(2) < Head > 头 部 标签 。 内 容 被 称 为 文件 头 ,包含 关 。。 站 
于 网 页 文档 的 信息 ,例如 网 页 的 标题 .脚本 样式 (CSS) 定 
义 及 文档 的 元 信息 等 ,这 些 信息 大 部 分 不 在 浏览 器 窗口 中 “图 6-17 HTML 文档 基 本 结构 
显示 。 元 信息 是 指 网 页 的 设计 日 期 .作者 .版 权 及 关键 字 
等 ,以 便 用 户 了 解 网 页 的 基本 情况 ,同时 供 搜索 引擎 进行 分 类 搜索 。 

(3) <Tite > 标题 标签 。 用 于 设 定 HTML 文档 标题 内 容 , 应 用 于 < Head > 和 </Head 
> 标签 之 间 ,是 网 页 头 部 不 可 或 缺 的 一 部 分 。 每 一 个 HTML 文档 都 必须 有 且 只 有 一 个 < 
Title > 标签 ,浏览 网 页 时 ,在 浏览 器 窗口 的 标题 栏 中 显示 文档 标题 内 容 。 

(4) < Body > 主体 标签 。 用 于 指明 HTML 文档 的 主体 区 ,是 网 页 的 可 见 部 分 ,可 以 包 
含 文本 ,图像 链接 ,音频 ,视频 ,表格 和 表单 等 各 种 内 容 。 











6.4.4 <Body > 页面 主体 标签 


<Body > … </Body > 标志 着 一 个 网 页 文档 的 主体 区 ,包含 浏览 器 中 显示 的 信息 。 < 
Body > 标签 的 属性 用 于 设置 整个 页 面 ,例如 网 页 的 背景 颜色 .背景 图 案 .文字 颜色 及 链 
接 等 。 

标签 格式 : 


<Body Bgcolor -背景 颜色 值 Background -背景 图 文件 名 
Text -文字 颜色 值 :主体 区 各 种 元 素 </Body > 


<Body > 标签 的 常用 属性 如 表 6-1 所 示 。 
表 6-1 <Body > 标签 的 常用 属性 
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属性 DW 名 说 明 示例 





设置 网 页 的 背景 色 , 属 性 值 是 颜色 
Bgcolor 背景 颜色 | 名 称 或 #RRGGBB 格式 的 十 六 进 | < Body Bgcolor =" Black" > 

















制 数 
Background | 背景 图 像 | 设置 网 页 的 背景 图 像 文 件 名 et em 
Text 文本 颜色 | 设置 网 页 内 文本 的 颜色 值 < Body Text = "#FFO000" > 


【 例 6.2】 设置 网 页 的 背景 为 灰色 ,文字 颜色 为 红色 。 


<Html ><Head > <Meta CharSet ="uft -8"/ ><Title > 网 页 颜色 </Title > </Head> 
<Body Bgcolor ="#*ccccc" Text = Red" > 
欢迎 访问 人 才 招 聘 网 ! 
</Body ></Html > 


6.5 文本 与 图 像 设 计 


文本 格式 的 设 定 可 以 直接 从 HTML 入 手 ,也 可 以 通过 Dreamweaver 工具 来 实现 ,本 节 
先 介绍 HTML 的 基本 设计 方法 ,以 便 更 好 地 理解 HTML 的 基本 设计 原理 。 


6.5.1 标题 级 别 


1. Hn 标签 


标签 格式 : 

<Hn Align = 对 齐 方式 ………: 淋 题 内 容 </Hn> 

网 页 的 主体 区 中 可 以 设计 <Hl > 、<H2 > 、…… < H6 >6 级 标题 ,标题 标签 标识 的 文 
字 独 占 一 行 显示 。 标 题 级 别 决 定 了 字号 的 大 小 和 粗细 程度 ,系统 默认 数字 越 小 ,级 别 越 
高 ,因此 ,一 级 标题 < HI > 字号 最 大 ,六 级 标题 < H6 > 字号 最 小 。 通 过 标题 的 属性 可 以 重 
新 设置 标题 的 样式 。 

【 例 6.3】 设计 各 级 标题 ,页 面 效果 如 图 6-18 所 示 。 

<Html > <Head ><Meta CharSet ="utf -8"/ ><Title > 标题 示例 </Title ></Head > 

<Body ><HL > 人 才 招 聘 网 wwHL > <82 :商场 资讯 </H2 ><H3 > 个 人 简历 </H3 > 


<H4 准 业 服务 </H4 ><H5 : 凌 位 选择 </H5 ><H6 > 创业 培训 </H6 > 
</Body ></Html > 


2. 选择 标题 的 操作 
通过 属性 面板 可 以 选择 对 应 的 标题 级 别 。 选 中 文档 中 的 一 段 文字 , 单 击 “ 属 性 "面板 
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HTML 选项 ,从 “格式 "列表 中 选择 “标题 1" 至 “标题 6" 之 一 ,如 图 6-18 所 示 。 


Dw | 应 用 程序 开发 人 员 ” [hen 


文件 人。 编辑 (EB 查看 (W) 插入 (D 修改 9 格式 (中 命令 (0 











职场 资讯 
企业 服务 
了 位 选择 区 一] 


剑 业 培 弄 


Ei 


mns 国 > 








aay>r3 [JR 村 lx 299v 1K7T 秒 Unicode QTF-8 















































属性 
《> TIL] ， 格式 到 ) 标题 加 类 无 = B 
Bcss IO 无 | 链接 C) 




















Ca 





图 6-18 选择 标题 级 别 下 拉 框 


6.5.2 段落 与 换行 

在 浏览 纯正 文 内 容 时 , 仅 当 信息 超过 浏览 器 宽度 时 才 自 动 换 行 。 要 使 信息 自 成 段落 
或 另 起 一 行 输出 , 除 加 标题 标签 外 ,还 可 以 用 换行 和 段落 等 标签 。 

1. 换行 标签 


换行 标签 <Br > 、</Br > 或 < BY > 是 单 标签 ,从 该 标签 位 置 开始 另 起 一 行 输出 


2. 段落 标签 
标签 格式 : 
< Align -对 齐 方式 ……， 刁 落 内 容 </P> 


段落 标签 用 于 划分 一 个 段落 ,段落 的 内 容 可 以 是 文本 及 图 像 等 其 他 类 型 的 对 象 。 浏 
览 器 在 处 理 <P > 标签 时 ,将 另 起 一 行 及 一 个 空白 行 , 即 各 段落 之 间 空 一 行 。 

Align 属性 用 来 设置 段落 在 浏览 器 中 的 对 齐 方式 ,属性 值 " Left" 表示 左 对 齐 ; 
“Right” 表示 右 对 齐 ;“ Center" 表示 居中 。 

【 例 6.4】 设置 段落 与 换行 ,页 面 效果 如 图 6-19 所 示 。 
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<Html > 人 
<Head > <Meta charset "utf -8"/> 图 段落 与 换行 ~ Microso- - - 加 加 四 
<ritle 小 落 与 换行 JTitle ></Head> EE 天 3 浊 | 考 
<Body > < 冷落 效果 </ 曙 > : QFE -©- 国 加 名 地址 四) 
< Align "Center" > 招聘 信息 </P > 2 

<P Align "Center" 半 职 信息 </P> 段落 效 果 
本 ee "Right" 装 职 论坛 wP> 招聘 信息 

行 效 果 </HL > 

< 也 Align ="'Center" 潮 聘 信息 Br/ > 
求职 信息 <Br/ > 求职 论坛 </P> 


</Body ></Html > a 
换行 效果 


求职 信息 





3. 设置 换行 和 段落 的 操作 
招聘 信息 
在 文档 窗口 的 设计 视图 中 输入 一 段 文 求职 信息 
字 后 按 Enter 键 , 就 形成 一 个 段落 ,内 容 包 求职 论坛 
含 在 <P>… </P > 标签 中 ; 按 Shift + Enter 
图 6-19 段落 浏览 效果 


键 , 即 换行 ,生成 < By > 标签 。 
通过 “属性 "面板 设置 段落 的 方法 : 选 
中 一 段 文字 , 单 击 “ 属 性 "面板 上 的 HTML 选项 ,在 “格式 "下 拉 列 表 中 选择 "段落 "。 
6.5.3 文本 基本 属性 
文本 是 网 页 信息 的 主要 载体 ,文本 的 基本 属性 有 字体 .字号 和 字 的 颜色 等 。 


1. Font 标签 
文本 的 标签 为 <Font > … </Font > 。 可 以 通过 设置 < Font > 标签 的 





属性 值 来 设置 


文本 的 字体 .字号 和 文字 颜色 。 
标签 格式 : 


<Eont Face -字体 Size 学 号 Color = 文字 颜色 值 汶 字 内 容 </Font > 


< Font > 标签 的 常用 属性 如 表 6-2 所 示 。 
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表 6-2 ”<Font > 标签 的 常用 属性 

















属性 DW 名 说 明 示 例 

Face 字体 设置 文本 的 字体 名 < Font Face = "隶书 " > 吉林 大 学 </Font > 
Size 大 小 设置 文本 的 字号 值 <Font size =" 5" > 人 才 招 聘 < /Font > 
Color 文字 颜色 设置 文本 的 字 颜 色 值 | <Font Color=" blue" > 推荐 人 才 </Font > 





其 中 Size 值 范围 为 1 ~7 ,数值 越 大 , 字 越 大 。 如 果 超 出 这 一 范围 , 则 按 下 限 或 上 限 值 
设置 字号 。Size 默认 值 为 3, 如 果 Size 的 值 为 +n 的 形式 , 则 表示 3 +n。 例 如 Size = +2 
表示 Size 的 值 为 5;Size = +10 表示 Size 的 值 为 7(3 +10 = 13 超出 上 限 7, 按 7 设置 ) 。 

【 例 6.5】 设置 文本 字号 .字体 和 颜色 等 属性 ,页 面 效 果 如 图 6-20 所 示 。 


<Html ><Head > 
<Meta CharSet ="utf -8"/ > 
<Title 汶 本 基本 属性 实例 </Title > </Head > 
<Body ><Eont Size =7" > 人 才 招 聘 网 </Font ><Br > 
<Eont Face 一 "华文 楷体 " > 个 人 简历 </Font ><Br > 
<Eont Color = 晶 066FF" > 职场 资讯 </Font ><Br > 
<Eont Face =" 黑体" Color ="Red" 
Size ="6" > 创业 培训 </Font > 
</Body > </Html > 





3 文本 基本 属性 实例 - Micros... 国 |[mlE:d 


; 文件 (FE) 编辑 (E) 查看 (Y) 收藏 A) 工具 (TD) ”> 万 


人 才 招 聘 网 





个 人 简历 
职场 资讯 


创业 培训 





图 6-20 文本 基本 属性 效果 


2. 设置 文本 属性 的 操作 


设置 文本 属性 的 具体 操作 步 又 如 下 : 
(1) 选择 CSS 选项 。 选 中 一 段 文字 , 单 击 “ 属 性 ”面板 的 CSS 选项 ,如 图 6-21 所 示 。 






































图 6-21 设置 字体 基本 属性 面板 
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(2) 编辑 字体 列表 ,如 图 6-22 所 示 。 字 体 列表 中 默认 有 13 种 字体 , 若 要 用 的 字体 不 
在 字体 列表 中 , 则 需要 在 “字体 "下 拉 列 表 中 选择 “编辑 字体 列表 …” 选 项 ,在 “编辑 字体 列 
表 ” 对 话 框 中 , “字体 列 表 ” 为 当前 已 有 的 字体 组 合 ,“ 可 用 字体 "列表 框 为 当前 还 没有 选择 
的 字体 ,在 其 中 选择 一 种 字体 , 单 击 “*<" 按 钮 可 将 该 字体 添加 到 “选择 的 字体 "列表 框 中 。 
编辑 完成 后 单 击 “ 确 定 ”按钮 。 





编辑 字体 列表 
































图 6-22 “编辑 字体 列表 ”对话 框 


(3) 新 建 CSS 规则 。 在 “字体 "下 拉 列 表 框 中 选择 字体 ,如 “黑体 "。 在 “新 建 CSS 规 
则 ”对话 框 中 ,“ 选 择 融 类 型 "为 “类 ( 可 应 用 于 任何 HTML 元 素 )" ,在 “选择 器 名 称 "文本 
框 中 输入 目标 规则 ( 样式) 名称, 如 "text” , 单 击 “ 确 定 ” 按 钮 。 

(4) 在 “属性 "面板 中 可 设置 文本 的 “大 小 ”及 “文本 颜色 ”。 


6.5.4 文本 格式 标签 


1. 文本 格式 标签 


用 文本 格式 标签 修饰 网 页 中 的 文字 格式 ,如 文字 加 粗 < Strong > ,倾斜 < Em > .加 下 
画 线 <U > 、 加 删除 线 <S > 、 上 标 < Sup >、 下 标 < Sub > 、 大 字体 < Big > 和 小 字体 < 
Small > 。 


【 例 6.6】 设置 文本 格式 如 斜体 .下 画 线 和 删除 线 等 ,效果 如 图 6-23 所 示 。 


<Html ><Head ><Meta CharSet ="utf -8"/ ><Title > 文本 格式 化 示例 </Title ></Head > 
<Body ><Strong ><Big > 人 才 招 聘 网 </Big ></Strong ><Br > 
<Em><Small 效 企 招聘 </Small ></Em><Br> 
<U > 个 人 简历 <wU><BR > < 浇 位 名 称 </S><Br> 
X<Sup 况 </Sup 王 <Sub 六 </Sub ><Br ></Body ></Html > 





2. 设置 文本 格式 属性 的 操作 


从 选中 文本 的 右 击 菜单 中 选择 “样式 "下 的 相关 选项 可 设置 文本 格式 。 有 些 标签 需 
要 单 击 “ 插 入 "菜单 一 “标签 "选项 ,在 “标签 选择 咒 " 中 添加 相关 格式 ,如 < Sub > 、< Sup 
>、<Small> 和 <Big> 等 。 
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3 文本 格式 化 示例 - Micro. . .全 | 口 区 | 
; 文件 EF) 编辑 下) 查看 (2) 收藏 (&) 了 








图 6-23 文本 格式 化 效果 


6.5.5 图 像 的 添加 与 设置 


图 像 是 网 页 中 重要 的 元 素 之 一 ,不 仅 具 有 烘托 网 页 主题 的 作用 ,也 能 加 深 用 户 对 网 站 


的 印象 。 
1. IMG 标签 
图 像 的 标签 为 <IMG > ,是 一 个 单 标签 ,用 /闭合 。 


标签 格式 : 


<IMG src - 源 文件 名 Alt = 蔽 换文 字 Align = 对 齐 方式 Border -边框 宽度 值 
Height -高 度 值 Width -宽度 值 Hspace 水平 边 距 值 Vspace = 垂直 边 距 值 /> 


当 浏览 器 读 取 到 <IMG > 标签 时 ,显示 此 标签 所 设 定 的 图 像 ,常用 属性 如 表 6-3 所 示 。 
表 6-3 ”<IMG > 标签 的 常用 属性 



































属性 DW 名 说 明 示例 
图 像 文件 的 URL 地 址 , 即 文件 名 及 
3 源 文 件 。 | 相对 路 径 或 绝对 路 径 
这 二 示 蕊 换 | <IMG Sre ="../Image /bj. jpg" 
Alt 替换 于 法 加 裁 哮 ; 寻 显示 着 换 Alt = "无 法 加 载 图 像 " Align = "left"/ > 
Align 对 齐 图 像 对 齐 方式 
Border 边框 图 像 边框 的 宽度 
Height 高 图 像 的 高 度 大 小 ,其 值 可 为 像素 数 | <IMG Sre = "Image /logo. gif" 

- Border ="2" Width = "400" 
Width | 宽 图 像 的 宽度 大 小 ,其 值 可 为 像素 数 | 。 Heisht "300" Hpace ="10" 
Hspace 水 平 边 距 | 图 像 距 左右 对 象 的 距离 Vspace ="10"/ > 
Vspace 垂直 边 距 | 图 像 距 上 下 对 象 的 距离 


为 了 使 网 页 方便 访问 图 像 文件 ,通常 将 其 存储 于 本 地 站 点 的 某 文 件 夹 中 ,如 Image 文 


件 炎 。 
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【 例 6.7】 在 网 页 中 显示 一 幅 边框 宽度 为 15 像素 ,宽度 为 458 像素 ,高 度 为 336 像 
素 , 存 储 在 站 点 根 目录 的 Image 文件 夹 中 的 图 像 LOGO. JPG。 


<Html ><Head ><Meta CharSset ="utf -8"/ ><Title > 回 像 基本 属性 </Title ></Head > 
<Body ><IMG Border 2"15" SRC "Image/LIOGO.JPG" ALT 一 "无 法 加 载 图 像 " 
Width ="458" Height 2"336" / ></Body ></Html > 


2. 设置 图 像 属性 的 操作 
将 光标 定位 于 要 插入 图 像 的 位 置 , 单 击 “ 择 入 "菜单 一 * 图像 "选项 ,在 “选择 图 像 源 文 


件 " 对 话 框 中 ,选择 图 像 文件 (如 Logo. JPG) 后 , 单 击 “ 确 定 " 按 钮 。 
在 “属性 ”面板 中 可 以 设置 图 像 的 相关 属性 ,如 图 6-24 所 示 。 

















同 源 文件 GJjrwazeylozo eif 加 已 葵 扫 四 无 法 加 就 图 售 。 区 














Ft 加 局 全 tp 了 
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原始 TEST = 


图 6-24 “图 像 "的 属性 面板 


















































(1) 宽 和 高 : 以 像素 为 单位 设 定 图 像 的 宽度 和 高 度 。 

(2) 源 文件 : 指定 图 像 的 具体 路 径 及 文件 名 。 

(3) 替换 : 当 浏 览 器 无 法 显示 图 像 时 ,在 图 像 位 置 显示 该 文字 信息 。 
(4) 边框 : 以 像素 为 单位 设 定 图 像 边 框 的 宽度 。 


6.6 链接 与 锚 记 设计 


网 页 中 通常 用 链接 (也 称 超 链接 ) 关 联 其 他 网 页 或 网 站 。 主 要 依据 文字 或 图 像 (也 称 
链接 对 象 ) 创建 链接 ,通过 引用 对 象 关联 其 他 文件 名 、 网 站 域名 ( 卫 地 址 ) 及 E-mail 地 址 


等 ,在 网 页 中 通常 用 链接 实现 网 页 导航 。 
在 浏览 器 中 ,链接 文字 对 象 通常 带 有 下 面 线 和 特殊 颜色 ,鼠标 指针 移动 到 链接 对 象 


时 ,指针 变 成 手 形 ; 单 击 链接 对 象 后 ,将 跳 转 到 链接 对 象 引用 的 对 象 网 页 。 
6.6.1 链接 设计 
标签 格式 : 


< Href =" 引 用 对 象 名 " Target = 浏览 引用 对 象 的 窗口 名 "> 链接 对 象 内 容 </A> 


1. 引用 对 象 名 
引用 对 象 名 是 链接 要 跳 转 的 目标 资源 名 , 可 以 是 文件 名 、 网 站 域名 (IP 地 址 ) 及 
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E-mail 地 址 。 常 用 引用 对 象 的 含义 如 表 64 所 示 。 











表 6-4 引用 对 象 表 
引用 对 象 类 型 说 明 示例 
链接 对 象 打开 的 目标 文件 名 ,可 含 记忆 WO 
文件 名 路 径 , 通 常 是 网 页 和 图 像 等 文件 <A Href ="../index. html" > 首页 </A > 
网 站 域名 (IP 地 | 链接 对 象 要 跳 转 的 目标 网 站 域名 或 | < A Href ="http://www. jlu. edu. cn" > 
址 ) IP 地 址 吉林 大 学 </A > 
Email 地 址 链接 对 象 要 发 送 Email 的 地 址 1 "mailto: wim@ sina. com" > 王 丽 敏 








2. 浏览 引用 对 象 的 目标 窗口 名 


浏览 引用 对 象 的 目标 窗口 用 于 说 明 打 开 引 用 对 象 的 位 置 。 该 窗口 名 可 以 是 网 页 中 定 
义 的 框架 名 ,例如 ,<a href ="bbsright. html" target = "f2" > 讨论 区 首页 </a > ,其 中 fi2 
为 框架 名 。 此 外 ,还 可 以 是 如 表 6-5 所 示 的 系统 值 。 


表 6-5 目标 窗口 的 系统 值 


系统 设置 值 说 明 示例 

<A Href ="../index. html" Target =" 
blank" > 首页 </A > 

<A Href ="../index. html" Target =" _Self" 
> 首页 </A> 





_Blank 或 _New | 新 窗口 打开 引用 对 象 





_Self 在 当前 网 页 窗口 中 打开 引用 对 象 





_Parent 当前 网 页 的 父 窗口 中 打开 引用 对 象 





<A Href =" http://www. jlu. edu. cn" Target 


_Top 顶层 窗口 中 打开 引用 对 象 ="_Top" > 吉林 大 学 </A > 








3. 链接 对 象 内 容 

链接 对 象 内 容 是 用 户 通过 浏览 器 由 一 个 网 页 跳 转 到 另 一 个 网 页 的 操作 对 象 ,通常 是 
浏览 器 中 可 见 的 内 容 , 如 文字 (如 表 6-5 中 的 “吉林 大 学 ”) 和 图 像 等 。 例 如 , < A Href = 
"Index. html" > <IMG Src ="../Image/Logo. gif" Width =135 Hight =100 > </A > 。 


4. 链接 设计 向 导 


选中 链接 对 象 内 容 , 在 “属性 "面板 的 “链接 " 框 中 输入 引用 对 象 名 或 单 击 “ 浏 览 文 
件 " 按 钮 ,选择 引用 对 象 。 在 “目标 "下 拉 列 表 中 选择 浏览 引用 对 象 的 目标 窗口 名 ,如 图 6- 
25 所 示 。 

单 击 * 插 入 "面板 一 常用 "一 “超级 链接 "按钮 ,在 “超级 链接 "对 话 框 中 也 可 以 设置 
链接 的 相关 参数 ,如 图 6-26 所 示 。 
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图 6-25 属性 面板 的 链接 























图 6-26 “超级 链接 "对 话 框 


6.6.2 引用 对 象 的 文件 路 径 


当 链接 的 引用 对 象 是 文件 名 时 ,文件 名 前 要 加 路 径 。 
1. 绝对 路 径 


绝对 路 径 是 完整 的 URL 地 址 ,如 http://www. jlu. edu. cn/Index. html 和 EE: \RCZP\ 
Image\BJ. gif。 由 “人 开始 的 路 径 表 示 从 站 点 主 目录 开始 ,如 /Index. html 是 站 点 主 目录 中 
的 文件 Index. html; /Image/bj. gf 是 站 点 主 目录 下 子 目录 Image 中 的 文件 bj. gif。 

绝对 路 径 的 优点 是 可 以 精确 地 定位 文件 ,缺点 是 不 利于 测试 和 站 点 移植 。 当 引用 当 
前 站 点 以 外 的 文件 时 通常 使 用 绝对 路 径 。 


2. 相对 路 径 


相对 路 径 是 指 以 当前 网 页 文件 所 在 的 文件 夹 (简称 当前 目录 ) 为 起 点 的 路 径 ,说 
明 当 前 网 页 文件 与 引用 文件 之 间 的 相对 位 置 关 系 ,因此 ,在 创建 设计 链接 前 ,应 该 保 
存 当前 网 页 文件 ,以 便 确定 相对 路 径 的 起 始 位 置 。 常 见 的 相对 路 径 有 如 下 几 种 书写 
形式 : 

(1) 当前 目录 : 直接 写 文件 名 或 文件 名 前 加 "*./”, 如 Index. html 或 . /Index. html。 

(2) 当前 目录 下 的 子 目 录 : 直接 写 子 目录 名 和 */" ,例如 ,Image/bj. gif。 表 示 引 用 当 
前 目录 下 Image 文件 夹 中 的 文件 bj. gif。 

(3) 前 级 目录 :“../” 表 示 前 级 目录 。 如 ../RCZP. HTML 表示 当前 目录 中 前 级 目录 
的 RCZP. HTML;../Image/bj. gif 表示 当前 目录 的 同 级 目录 Image 中 的 bj. gif 文件 。 
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6.6.3 ”设计 链接 文字 的 颜色 


1. 链接 的 状态 

一 个 链接 通常 有 如 下 4 种 状态 : 

(1) 初始 链接 : 是 网 页 中 链接 的 初始 状态 ,有 些 网 页 以 蓝 色 显示 链接 对 象 的 文字 。 

(2) 已 访问 链接 : 访问 ( 单 击 ) 过 的 链接 ,有 些 网 页 以 紫色 显示 链接 对 象 的 文字 。 

(3) 活动 链接 : 在 链接 对 象 上 按 下 鼠标 左 键 和 抬 起 之 间 , 有 些 网 页 改变 链接 对 象 的 
文字 颜色 。 

(4) 变换 图 像 链接 : 鼠标 指针 移 到 链接 对 象 上 变 为 手 形 时 的 链接 , 某 些 网 页 同时 改 
变 链接 对 象 文 字 的 颜色 。 

2. 设置 链接 颜色 的 属性 

链接 对 象 各 种 状态 的 文字 颜色 与 具体 的 网 页 设计 有 关 。 用 < Body > 标签 的 有 关 属 性 
(如 表 6-6 所 示 ) 可 以 设置 链接 对 象 的 文字 的 各 种 颜色 。 

表 6-6 链接 对 象 的 文字 颜色 属性 











属性 DW 名 说 明 示例 
Link 初始 链接 链接 的 初始 颜色 ,默认 为 蓝 色 <Body Link =" navy" Alink =" 
Alink( Active) | 活动 链接 活动 链接 的 颜色 maroon" Vlink = "gray”> 
- < A Href =" http://www. jlu. 
Vlink( Visited) | 已 访问 链接 ”| 被 访问 过 的 链接 颜色 


edu. cn " > 吉林 大 学 </A > 


Hover 变换 图 像 链接 | 鼠标 指针 为 手 形 时 的 文字 颜色 </Body > 














3. 设置 链接 文字 颜色 的 操作 

光标 置 于 < Body > 与 </Body > 之 间 , 通 过 下 列 操作 之 一 均 可 设置 链接 对 象 的 文字 
颜色 : 

(1) 链接 对 象 文字 颜色 的 样式 : 单 击 “ 属 性 "面板 的 “页 面 属性 "按钮 ,在 “页 面 属性 ” 
对 话 框 中 选择 “链接 ( CSS) "分 类 ,设置 链接 对 象 的 文字 颜色 如 图 6-27 所 示 。 


分 类 链接 (css) 
外 (css) 











外 OTML) 链接 字体 LI); |( 同 页 面 字 体 ) 
es 大 小 @) 司 图 








J 
光 才 链接 颜色 C) : 可 | #00F 变换 图 你 链接 @) : 加 | 
已 沪 问 链接 QD: 天 | sc09 ”| 。 活动 链接 内: 剧 
下 其 样式 D ; [部 终 有 下 画 线 


CO Dw 





















































图 6-27 “页 面 属性 "对 话 框 
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(2) 网 页 中 链接 对 象 的 文字 颜色 : 在 Body 标签 的 “页 面 属性 "对话 框 中 ,选择 分 类 为 
“外 观 (HTML)”, 设 置 方法 与 图 6-27 类 似 , 但 不 能 设置 变换 图 像 的 链接 对 象 文字 颜色 。 


6.6.4 锚 记 链接 


链接 用 于 设计 跳 转 到 当前 网 页 文件 之 外 , 即 实现 网 页 之 间 的 跳 转 。 要 实现 网 页 内 部 
的 跳 转 ,需要 锚 记 链接 。 

设计 锚 记 链接 首先 要 命名 锚 记 ( 锚 点 ) ,作为 链接 的 目标 ,再 设计 指向 锚 点 的 链接 。 
命名 锚 记 是 设置 网 页 中 的 锚 点 。 浏 览 网 页 单 击 锚 记 链接 后 ,光标 定位 到 对 应 的 锚 点 。 


1. 设计 锚 记 链接 


设计 锚 记 链接 需要 以 下 步骤 : 
(1) 命名 锚 记 : 在 文档 的 代码 视图 下 ,在 锚 点 位 置 输入 下 列 标签 ,为 锚 点 命名 ; 
标签 格式 : 


< 人 Name 二 锚 记 名 称 " 或 ID 汪 锚 记名 "></R> 


(2) 设计 锚 记 链接 : 在 网 页 中 ,用 下 列 标签 描述 链接 对 象 的 内 容 : 
标签 格式 : 


人 Href 下 ' 煤 记名 称 " > 链接 对 象 的 内 容 </A> 


2. 设计 锚 记 链接 的 操作 


(1) 命名 锚 记 : 在 页 面 需 要 跳 转 的 目标 位 置 定位 插入 点 , 单 击 “ 插 入 ”面板 一 “常用 ”一 
“命名 锚 记 ”按钮 ,在 “命名 锚 记 "对话 框 中 设置 锚 
记名 称 , 如 图 6-28 所 示 , 单 击 “ 确 定 ” 按 钮 。 

(2) 设计 锚 记 链接 : 设计 锚 记 链接 的 方法 
与 链接 类 似 , 先 选中 链接 对 象 , 再 单 击 * 插 入 " 面 
板 一 “常用 "一 “超级 链接 ”按钮 ,在 “超级 链接 ” 
对 话 框 中 ,从 “链接 "下 拉 框 中 选择 锚 记 名 ,或 输 
入 “# 锁 记名 ”。 选 中 链接 对 象 后 ,从 “属性 "面板 
的 “链接 "下 拉 框 中 也 可 以 直接 选择 锚 记 名 称 ,创建 锚 记 链接 。 

【 例 6.8】 设计 网 页 Index. html, 网 页 顶部 有 logo. gif 图 像 ,下 面 是 Hl 标题 字 “ 人才 
招聘 " ,再 下 方 为 首页 .招聘 信息 求职 信息 和 求职 论坛 的 链接 向 导 。 

(1) 在 “文件 "面板 中 ,选择 RCZP 为 当前 站 点 。 

(2) 单 击 “ 文 件 " 菜 单一 “新 建 " 选 项 ,选择 “新 建文 档 " 对 话 框 中 的 “页 面 类 型 "为 
HTML, “布局 "为 “无 ”, 单 击 “ 创 建 " 按 钮 ,新 建 一 个 空白 文件 。 

(3) 在 “代码 "视图 下 ,将 “无 标题 文档 ” 改 为 “欢迎 访问 人 才 招 聘 网 !1”。 

(4) 单 击 “ 文 件 " 菜 单一 “保存 "选项 , 存 于 站 点 主 目录 下 的 Index. html。 

(5) 在 “设计 "视图 中 , 单 击 “ 插 入 "菜单 一 "图像" 选项, 在“ 图像 源 文件 "对 话 框 中 选 
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图 6-28 “命名 锚 记 ”对 话 杠 


加 


择 Image 文件 夹 中 的 logo. gif。 选 中 图 片 ,在 “属性 "面板 中 设置 “ 宽 " 为 135,“ 高 ”为 100， 
“替换 "为 "人才 招 聘 ” ,链接 "为 Index. php,“ 目 标 " 为 _self。 

(6) 按 Enter 键 ,输入 * 人 才 招 聘 ” ,在 “属性 "面板 中 设置 “格式 "为 “标题 1”。 

(7) 按 Enter 键 ,依次 输入 并 选中 首页 .招聘 信息 ,求职 信息 和 求职 论坛 ,在 “属性 " 面 
板 中 分 别 设置 “链接 "为 Index. php .Jobs. php .Resume. php 和 BBS. php。 

(8) 按 F12 键 保存 文件 并 在 浏览 器 中 预览 网 页 。 





6.7 水 平 线 及 媒体 播放 设计 


网 页 内 容 除 文本 以 外 ,还 有 图 像 动画 ,视频 和 音频 等 ,整个 网 页 布局 是 各 种 网 页 元 素 
的 有 机 组 合体 。 根 据 不 同 的 网 站 主题 ,可 以 设计 出 各 有 具 特色 的 网 站 。 
6.7.1 水 平 线 


水 平 线 可 以 将 网 页 在 视觉 上 分 成 几 个 区 域 ,使 网 页 内 容 显得 清晰 明了 。 
1. 水 平 线 标签 














标签 格式 : 
<HR Color - 线 颜 色 值 Size - 线 粗 度 值 Width - 线 宽度 值 Align = 对 齐 方式 /> 
常用 属性 如 表 6-7 所 示 。 
表 6-7 水平 线 标签 的 常用 属性 
属性 DW 名 说 明 示例 
Color 线 的 颜色 ,默认 为 黑色 <Hr Color =" blue" /> 
Size 高 线 的 粗细 , 值 越 大 , 线 越 粗 <Hr Size =" 2" /> 
i 宽 线 的 宽度 (长 度 ) , 值 可 为 绝对 长 度 ( 像素 数 ) <Hr Width =" 200"/ > 
或 相对 长 度 ( 网 页 宽度 的 百分比 ) <Hr Width=" 80%"/ > 
Align 对 齐 | 线 的 对 齐 方式 <Hr Align =" center" / > 











2. 设置 水 平 线 的 操作 


在 设计 视图 下 ,将 光标 定位 到 要 插入 的 水 平 线 位 置 , 单 击 “ 插 入 "菜单 一 HTML 一 “水 
平 线 " 选 项 ,选中 水 平 线 ,在 “属性 "面板 中 设置 相关 属性 ,如 图 6-29 所 示 。 


6.7.2 多 媒体 对 象 


根据 网 页 的 整体 布局 和 设计 风格 ,合理 地 插入 动画 ,视频 和 音频 ,能 使 网 页 更 加 丰富 
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图 6-29 ”水平线 属性 面板 


多 彩 和 生动 形象 。 
1. 插入 SWF 动画 文件 


光标 定位 到 要 插入 动画 的 位 置 , 单 击 “ 插 入 "菜单 一 “媒体 ”一 SWF 选项 ,从 “选择 
SWF" 对话 框 中 选择 文件 , 单 击 * 确 定 "按钮 。 在 “属性 ?面板 中 设置 动画 的 相关 属性 ,如 
图 6-30 所 示 。 
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图 6-30 “SWF 动画 ”的 属性 面板 


(1) 宽 和 高 : 设置 SWF 动画 的 尺寸 。 

(2) 文件 : 指定 SWF 文件 及 路 径 。 

(3) 背景 颜色 : 指定 动画 区 域 的 背景 颜色 ,在 动画 加 载 和 播放 后 也 显示 此 颜色 。 
(4) 循环 : 选中 表示 重复 播放 动画 。 

(5) 自动 播放 : 选中 表示 载 人 文档 后 自动 播放 动画 。 

(6) 垂直 边 距 和 水 平 边 距 : 指定 动画 边框 与 网 页 上 边界 和 左边 界 的 距离 。 

(7) 品质 : 设置 SWF 动画 在 浏览 器 中 的 播放 质量 。 

(8) 比例 及 对 齐 : 设置 显示 比例 和 动画 在 页 面 中 的 对 齐 方式 。 

(9) 播放 : 在 “文档 "窗口 中 播放 。 


2. 插入 FLYV 视频 


在 设计 视图 下 ,将 光标 定位 到 要 插入 视频 的 位 置 , 单 击 “ 插 入 "菜单 一 “媒体 "一 FLV 
选项 ,在 “插入 FLV" 对 话 框 中 单 击 “ 浏 览 " 按 钮 ,选择 视频 文件 , 单 击 “确定 "按钮 。 在 “ 插 
入 FLV” 对 话 框 中 进行 设置 ,如 图 6-31 所 示 , 单 击 “ 确 定 ” 按 钮 。 


3. 插入 背景 音乐 


用 插件 播放 音频 会 占用 一 定 的 网 页 空间 ,因此 ,通常 采用 添加 背景 音乐 的 方式 在 网 页 
中 插入 音频 ,在 打开 网 页 时 既 自动 播放 音乐 ,又 不 占用 更 多 的 网 页 空间 。 

单 击 “ 插 入 "菜单 一 “标签 "选项 ,如 图 6-32 所 示 , 在 “标签 选择 器 " 对 话 框 中 展开 
“HTML 标签 ” , 单 击 * 页 面 元 素 "选项 ,选中 右 列 表 框 中 的 bgsound 选项 。 
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视频 类 型 : | 时 进 式 下 载 视频 本 | 全 到 二 
[取消 
WRL: Inaee/ 企 业 简介 . 昌 v | 
(输入 FLY 文件 的 相对 或 绝对 路 径 ) 
外 观 : |Clear Skin 1 (最 小 宽度 : 140) 对 | 
pln object 
paran (Applet) 
paran (Object) 
宽度 : | | 回 限制 高 宽 比 。[ 臣 测 大 小 
高 度 : ] 包括 外 观 : 
自动 播放 
自动 重新 播放 
CD。 更 看 视频 , 请 在 济 这 器 中 预 响 页 面 
图 6-31 “插入 FLV" 对 话 框 图 6-32 “标签 选择 器 "对 话 框 


单 击 “ 插 入 "按钮 ,在 “标签 编辑 器 -bgsound” 对 话 框 中 ,如 图 6-33 所 示 , 单 击 “ 源 "的 
“浏览 "按钮 ,选择 背景 音乐 文件 ;从 “循环 "下 拉 列 表 框 中 选择 “无 限 " 选 项 , 单 击 “ 确 定 ” 
按钮 ,返回 "标签 选择 器 " 对话 框 ,再 单 击 “ 关 闭 " 按 钮 。 

| 标签 编辑 器 - bgsound 
bgsound - 常规 


: [Inage/bgsound. mp3 EE 























图 6-33 “标签 编辑 器 -bgsound" 对 话 框 


6.8 CSS 设计 


设计 网 页 除 需 要 HTML 语言 外 ,还 需要 CSS( Cascading Style Sheets , 层 麦 样式 表 ,简称 
样式 表 ) 。CSS 主要 用 于 描述 XHTML 文档 的 样式 ,使 网 页 格式 化 ,网 站 整体 设计 风格 
= 





6.8.1 CSS 基础 


设计 网 页 时 ,通常 HTML 标签 定义 网 页 的 内 容 ,用 CSS 设计 修饰 标签 的 格式 。 可 以 
将 CSS 理解 为 一 个 预先 定义 的 格式 集合 ,与 HTML 文档 配合 使 用 。 当 浏览 器 读 到 样式 表 
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时 ,按照 样式 表 对 页 面 元 素 的 字体 样式 .背景 .表格 链接 .排列 方式 ,区域 尺寸 和 边框 等 显 
示 方 式 进行 控制 。 

一 个 CSS 样式 表 可 以 同时 作用 于 多 个 HTML 文档 ,如 果 将 整个 网 站 所 有 网 页 的 外 观 
样式 指向 同一 个 CSS ,可 以 使 网 站 的 整体 设计 风格 统一 。 修 改 CSS 中 的 某 个 样式 ,能 使 所 
有 相关 网 页 的 样式 随 之 变化 。 

使 用 CSS 能 够 简化 网 页 代码 ,加 快 下 载 速度 ,减少 重复 设计 ,便于 网 站 维护 。 


1. CSS 语法 基础 


层 盖 样式 表 包 含 一 组 样式 规则 ,可 以 直接 写 在 HTML 文档 中 ,也 可 以 单独 存储 在 扩 
展 名 为 CSS 的 文件 中 ,用 下 列 格式 描述 每 个 样式 。 

语法 格式 : 

选择 器 { 属性 1: 值 1 ; 属性 2: 值 2 ;… ; 属性 N: 值 N} 


(1) 选择 器 : 包含 类 型 说 明和 名 称 。 类 型 说 明 是 指 选择 器 的 类 型 ,主要 有 标记 选择 
器 .类 选择 器 和 ID 选择 器 ,而 名 称 可 以 是 英文 字母 及 其 开头 的 数字 或 减 号 ”- "的 组 合 ， 
一 般 根据 功能 或 效果 命名 。 
(2) 声明 : 要 用 花 括号 括 起 来 ,每 条 声明 由 一 个 属性 和 值 组 成 ,属性 和 值 用 冒号 分 
隔 , 声 明之 间 用 *;" 分 号 隔 开 。 类 型 名 称 “属性 1 值 ! ”属性 2 值 2 
例如 ,将 文字 颜色 定义 为 红色 ,字体 大 小 设置 1 | | | | 
为 16 像素 , 则 CSS 代码 的 结构 如 图 6-34 所 示 。 2 
其 中 “. "表示 类 选择 器 ;t-Red 是 选择 器 名 称 ; ”选择 器 声明 1 声明 2 
| Color: Red; Font-Size;16px;| 是 完整 的 声明 部 分 ， 图 6-34 CSS 代码 的 结构 
定义 颜色 为 红色 ,文字 大 小 为 16 像素 。 


2. CSS 样式 


在 CSS 样式 中 经 常 需 要 设置 字体 文本、 背景 等 属性 ,其 中 字体 属性 用 于 设置 文本 的 
字体 ,大 小 和 加 粗 等 ,文本 属性 用 于 设置 文本 的 颜色 和 对 齐 方式 等 ,背景 用 于 设置 背景 颜 
色 和 背景 图 片 ,常见 的 属性 如 表 6-8 所 示 。 


表 6-8 CSS 样式 的 常用 属性 






































属性 说 明 示例 
Font-Family 字体 | Font-Family:" 黑 体 " | 
Font-Size 字 的 尺寸 | Font-Size:18px| 
Font-Weight 字 的 粗细 | Font-Weight: Bold| 
Color 文本 颜色 | Color: Red| 
Text-Align 对 齐 方式 | Text-Align: Center| 
Trl Toralidn rs oe 除 下 并 {Text Decoration, Line-Through} 
Background-Color ”| 背景 颜色 | Background-Color:#FFO000} 
Background-Image “| 背景 图 像 | Background-Image:Url(. . /Image/ Bj. gif) | 
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6.8.2 CSS 选择 器 
1. 标记 选择 器 
标记 选择 器 一 般 用 于 整体 样式 的 控制 。 每 一 种 HTML 标签 都 可 以 作为 相应 的 标记 


选择 器 名 称 ,标记 选择 器 名 称 决 定 了 该 标签 采用 的 CSS 样式 。 例 如 ,P| Color:#FF0000; 
Text-Align: Center | 规定 所 有 <P > 标签 都 采用 红色 字 、 居 中 显示 的 统一 样式 风格 。 


2. 类 选择 器 


定义 类 选择 器 时 ,类 名 称 前 面 加 一 个 圆 点 ".”。 类 选择 器 可 以 应 用 到 HTML 标签 上 ， 
同一 个 类 选择 器 可 以 被 引用 多 次 。 

例如 ,定义 样式 . Center | Text-Align: Center| 和 . Red | Color: Red| ,HTML 代码 为 < Hl 
Class = "Center" > 吉林 大 学 </H1 > 和 <P Class = " Center" > 人 才 招 聘 </P > ,都 引用 了 
Center 类 选择 器 ,遵守 其 规则 。 一 个 标签 可 以 应 用 多 个 类 选择 器 ,将 多 种 样式 风格 同时 应 
用 到 一 个 标签 中 。 例 如 , <P Class =" Center Red" > 招聘 信息 </P > 引用 了 Center 和 Red 
类 ,将 同时 遵守 两 个 选择 器 的 规则 。 


3. Id 选择 器 


Id 选择 器 用 于 定义 单一 元 素 的 样式 ,为 标 有 特定 Id 的 元 素 指定 样式 。 定 义 Id 选择 
硕 时 ,类 名 称 前 面 加 一 个 “#" 号。 

例如 ,定义 样式 #First | Background: Lime| 和 #Next| Color: Blue | , HTML 代码 为 <P Id 
= "First" > 招聘 信息 </P > , P 元 素 背 景 为 黄 绿 色 。 

设计 网 页 时 ,类 选择 器 和 id 选择 器 的 视觉 效果 几乎 没有 差别 ,只 是 类 具有 普遍 性 ,而 
id 具有 特殊 性 。 因 此 重复 使 用 的 样式 用 类 选择 器 定义 ,单一 元 素 或 者 需要 JavaScript 控件 
的 元 素 用 Id 选择 器 定义 。 

与 类 选择 器 相 比 ,Id 选择 器 有 以 下 特点 : 

(1) 一 个 14 选择 器 只 能 在 一 个 HTML 文档 中 使 用 一 次 。 否 则 , 当 JavaScript 等 其 他 
脚本 语言 调用 它 时 会 出 现 意 想 不 到 的 错误 。 

(2) Id 选择 器 不 像 类 选择 器 一 样 能 多 个 合并 使 用 ,一 个 元 素 只 能 引用 一 个 Id 名 。 如 
<P Id ="First Next" > 是 错误 的 。 

Id 选择 器 主要 用 于 网 页 中 的 特殊 修饰 ,如 标志 .导航 栏 .主题 和 版 权 等 内 容 , 通 常 命 
名 为 #[Logo .#Nav \#Content 和 #Copyright 等 ,避免 与 其 他 样式 发 生 冲 突 。 


6.8.3 创建 CSS 


根据 样式 表 代 码 位 置 的 不 同 ,CSS 分 为 内 嵌 样 式 表 、 内 部 样式 表 和 外 部 样式 表 3 类 。 
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1. 内藤 样式 表 


内 艇 样式 表 也 称 内 联 样式 表 , 即 将 样式 代码 通过 Style 属性 直接 嵌 在 标签 内 , 仅 对 所 
在 标签 有 效 。 例 如 , <P Style = " Color:Sienna; Font-Size:20px" > 岗位 名 称 </P > 。 内 和 内 
样式 表 使 用 简单 直观 ,适用 于 仅 应 用 一 次 的 样式 。 


2. 内 部 样式 表 


内 部 样式 表 是 在 HTML 文档 的 < Head > 标签 内 使 用 < Style > 定义 样式 ,在 < Body > 标签 
内 引用 ,只 对 所 在 的 网 页 文档 内 容 有 效 。 

语法 格式 : 

<Head ><Style Type ="Text/Css" > 

<! -- 样式 表 的 具体 内 容 --> 

</Style ></Head > 

【 例 6.9】 在 HTML 文档 中 ,用 内 部 样式 表 设计 效果 如 图 6-35 所 示 的 网 页 。 具 体 样 
式 为 : 图 片 背景 颜色 是 紫色 ;文字 “人 才 招 聘 " 是 H1 ,红色 居中 显示 六 首 页 “招聘 信息 ” 
“求职 信息 ”和 “求职 论坛 "为 链接 ,文字 大 小 是 20px; 最 新 职位 “最 新 人 才 ” 和 ”推荐 企 
业 " 的 背景 图 片 是 Bj. gif, 文 字 颜 色 是 白色 。 





窒息 次 @ 访 问 人 才 招 聘 网 ! 








人 才 招 聘 


首 页 招聘 信息 求职 信息 求职 论坛 


要 新 人 才 








图 6-35 ”网 页 效果 
HTML 代码 如 下 : 


<HTML > <Head ><Meta Charset ="utf -8"/ ><Title 欢迎 访问 人 才 招聘 网 ! </Title > 
<Style Type ="Text/Css" > 
Hl{Color:Red; Text Align:right} 
非 ogo{Background -Color:Purple;} 
Wav{Font -Size:20px; } 
.Bj {Background -imge:Ur] (Image/Bj .gif); 
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Height :20px;Width:75px;Color:$FF;} </Style ></Head > 
<Body ><P Id ="l0go" ><A Href ~"Index.php" > 


<Img Src "Tmage/Logo.gif" Width ="135" Height ="100" Alt "logo"/ ></R></P> 
<HL > 人 才 招 聘 < 本 > 


< id="'nav"> 
< Href "Index.php" Target ~" self" 并 页 <A> 
< Href "Jobs.php" Target "self"” > 招聘 信息 </A> 
< Href ="Resume .php" Target ="' self" 水 职 信息 </A> 
< Href "BBS .php" Target = self" 半 职 论坛 YA><P> 
< Class =Bj" 北新 职位 <P><P Class ="Bj" > 县 新 人 才 </P> 
< class ="Bj" >x 推 荐 企业 </P> 
</Body ></Html > 
【 例 6.10]】 
步骤 如 下 : 


(1) 打开 例 6.8 中 的 Index. html。 


(2) 单 击 “ 窗 口 " 菜 单一 “CSS 样式 "选项 ,打开 “CSS 样式 "面板 ,如 图 6-36 所 示 , 单 击 
“新 建 CSS 规则 "按钮 。 


用 Dreamweaver 操作 及 内 部 样式 表 设计 例 6.9 的 网 页 。 


(3) 在 “新 建 CSS 规则 ”对 话 框 中 ,“ 选 择 器 类 型 "为 “ID( 仅 应 用 于 一 个 HTML 元 
素 )”, “选择 嚣 名称” 输入 Logo, 如 图 6-37 所 示 , 单 击 “ 确 定 ” 按 钮 。 


ET CSS 规则 









































不 太 由 体 。” ] [ 更 具体 
规则 定义 : 














-一 
“附加 样式 表 ” 按 钮 “新 建 CSS 规 则 ”按钮 
图 6-36 “CSS 样式 "面板 











帮助 





图 6-37 “新 建 CSS 规则 "对 话 框 
(4) 在 “#Logo 的 CSS 规则 定义 "对 话 框 中 ,如 图 6-38 所 示 ,选择 “分 类 "为 背景 " , 输 
人 Background-color 为 #800080, 单 击 “ 确 定 " 按 钮 。 

(5) 单 击 “CSS 样式 "面板 中 的 “新 建 CSS 规则 "按钮 ,在 “新 建 CSS 规则 "对话 框 中 ， 
设置 “选择 器 类 型 "为 “ID( 仅 应 用 于 一 个 HTML 元 素 )” ,输入 “选择 器 名 称 ” 为 Nav。 单 击 


“确定 "按钮, 在“#Nav 的 CSS 规则 定义 "对 话 框 中 ,选择 “分 类 " 栏 中 的 “类 型 " ,输入 Font- 
Size 为 20px。 单 击 “ 确 定 " 按 钮 ,完成 #Nav 的 CSS 规则 定义 。 


(6) 单 击 “CSS 样式 "面板 中 的 “新 建 CSS 规则 ”按钮 ,在 “新 建 CSS 规则 ”对 话 框 中 ， 
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#Logo 的 CSS 规则 定义 








Backer ound-color C): | #000080 
Backer ound-iasge OD): © a... 

Backeround-repeat (B): 
Backgr ound-attachaent (D) 
Backeround-position CD) 
Backeround-position (1) 
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图 6-38 


“#[Logo 的 CSS 规则 定义 ”对 话 框 


设置 “选择 器 类 型 "为 “标签 (重新 定义 一 个 HTML 元 素 ) ”, 输 入 “选择 器 名 称 " 为 HI 。 单 
击 “ 确 定 " 按 钮 ,在 “HIl 的 CSS 规则 定义 ”对 话 框 中 ,选择 “分 类 " 栏 中 的 “类 型 " ,输入 
Color 为 #F00 ,选择 “分 类 " 栏 中 的 “区 块 ” ,Text-align 选择 Center。 单 击 “ 确 定 ” 按 钮 ,完成 
Hl 的 CSS 规则 定义 。 

(7) 单 击 “CSS 样式 "面板 中 的 “新 建 CSS 规则 "按钮, 在“ 新建 CSS 规则 ”对 话 框 中 ， 
将 “选择 器 类 型 " 选 为 “类 (可 应 用 于 任何 HTML 元 素 )” ,输入 “选择 器 名 称 ” 为 Bj。 单 击 
“确定 ”按钮 ,在 “. Bj 的 CSS 规则 定义 ”对话 框 中 ,选择 “分 类 ” 栏 中 的 “类 型 " ,输入 Color 
为 #FFF ,选择 "分 类 " 栏 中 的 “背景 ”, 单 击 Background-imge 的 “浏览 "按钮 ,在 “选择 图 像 
源 文 件 " 对 话 框 中 选中 Image 文件 夹 中 的 Bj. gif 文件 。 单 击 * 确 定 "按钮 ,完成 . bj 的 CSS 
规则 定义 。 

(8) 在 “代码 "视图 中 ,选中 图 片 所 在 的 <P > 标签 ,从 * 属 性 ”面板 的 ID 下 拉 列 表 中 
选择 logo, 如 图 6-39 所 示 。 


类 无 - BI 注 注 经 二 标题 ID) ] 


"OD 上- 
[而 民 性 .. ] | 引 志 页 








图 6-39 “属性 "面板 


(9) 在 “代码 "视图 中 ,选中 链接 所 在 的 <P > 标签 ,从 “属性 "面板 的 ID 下 拉 列 表 中 
选择 nav。 

(10) 切换 到 “设计 "视图 ,可 以 看 到 格式 化 后 的 效果 。 在 链接 文字 下 方 依次 输入 “最 
新 职位 "最 新 人 才 ” 和 “推荐 企业 "三 段 文字 ,从 “属性 "面板 的 “类 ”下 拉 列 表 中 选择 Bj。 


3. 外 部 样式 表 


外 部 样式 表 将 CSS 样式 规则 独立 存储 于 扩展 名 为 CSS 的 文件 中 ,而 HTML 文件 通过 
链接 方式 引用 它 ,实现 网 页 HTML 与 CSS 代码 的 完全 分 离 。 外 部 样式 表 对 所 有 引用 它 的 
网 页 都 有 效 ,适用 于 设计 相同 样式 网 页 的 网 站 ,可 以 通过 修改 一 个 CSS 文件 来 改变 整个 
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网 站 的 风格 。 使 用 外 部 样式 表 , 可 以 减少 重复 代码 ,降低 下 载 数据 量 ,方便 网 页 维护 。 

外 部 样式 表 文 件 可 以 在 任何 文本 编辑 器 (如 记事 本 ) 中 进行 编辑 ,但 不 能 包含 任何 
HTML 标签 。 每 个 网 页 中 使 用 < Link > 标签 链接 到 样式 表 文 件 。 < Link > 标签 必须 放 到 
HTML 文档 的 头 部 < Head > </Head > 标签 内 。 

语法 格式 : 


<Link Rel ="Stylesheet" Type ="Text/Css" Href —"../Css/CSS 文件 名 "/ > 


浏览 器 根据 CSS 文件 修饰 格式 网 页 。 其 中 rel = " stylesheet" 表示 使 用 外 部 样式 表 ， 
type = " text/ess" 表示 文件 类 型 是 样式 表 文 本 ,href ="../css/CSS 文件 名 "指出 样式 表 文 
件 所 在 位 置 ,通常 使 用 相对 路 径 。 

【 例 6.11】 在 HTML 文档 中 ,使 用 外 部 样式 表 设 计 例 6.9 的 网 页 。 

设计 步骤 如 下 : 

(1) 使 用 记事 本 ,创建 ex. css 文件 ,存放 在 站 点 的 CSS 文件 夹 中 。CSS 代码 如 下 : 


Hl {Color:Red;Text Align:Center;} 

#0ogo{Background -Color:Purple;} 

av{Font -Size:20px;} 

.Bj {Background -image:Url (../Image/Bj .gif) ;Height :20px;Width:75px;Color:#FF;} 


(2) 使 用 记事 本 ,创建 Index1. html 文件 ,存放 在 站 点 的 根 目 录 下 。HTML 代码 如 下 : 


<HTML ><Head > Meta Charset ="utf -8"/ ><Title 欢迎 访问 人 才 招 聘 网 ! </Title > 
<Link Rel ="Stylesheet" Type ="Text/Css" Href ="../Css/Ex.css"/ ></Head > 
<Body> 
< Id="l0go" ><A Href ="Index.php" > 
<Img Src "TImage/logo.gif" Width ="135" Height ="100" Alt 2"l0go"/ ></R></P> 
<HL > 人 才 招 聘 </HL > 
< Id=nav"> 改 Href="Index.php" Target = self"x 首 页 </A> 
< Href = "Jobs.php" Target =" self" > 招聘 信息 </A> 
<A Href ="Resume .php" Target =" self" 水 职 信息 YA> 
< Href "BBS .php/" Target = self" 水 职 论 坛 YA><P> 
也 Class "Bj" 凝 新 职位 /P><P Class ="Bj" 瘟 新 人 才 <P> 
<P class ="Bj" >: 推荐 企业 </P> 
</Body ></Htm > 


(3) 在 浏览 器 中 查看 网 页 效果 。 

【 例 6.12】 使 用 外 部 样式 表 与 向 导 结 合 , 设 计 例 6.9 的 网 页 。 

步 又 如 下 : 

(1) 单 击 “ 文 件 " 菜 单一 “新 建 ” ,弹出 “新 建文 档 " 对 话 框 ,选择 “空白 页 "中 的 “CSS” 
文件 , 单 击 “ 创 建 "按钮 。 

(2) 在 新 建 的 CSS 文件 窗口 中 输入 CSS 代码 如 下 : 

Hl{Color:Red; Text Aliqn:Center;} 

韭 ogo{Background -Color:Purple;} 
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Wav{Font -Size:20px;} 

.Bj {Background -image:Url (. ./Image/BJ .gif) ;Height :20px;Width:75px;Color:$FF;} 

或 者 按照 例 6. 10 的 第 (2) ~ (7) 步 操作 ,然后 将 其 保存 在 CSS 文件 夹 ,名 为 Ex. css。 

(3) 单 击 “ 文 件 "菜单 一 “打开 ” ,打开 例 6. 8 已 建 的 Index. html 文件 , 单 击 “CSS 样 
式 " 面 板 的 “附加 样式 表 ” 按钮 。 在 “链接 外 部 样式 表 ” 对 话 框 中 ,从 “文件 /URL" 下 拉 列 
表 框 中 选择 css/ex. css, “添加 为 "选中 “链接 ”按钮 ,如 图 6-40 所 示 。 

(4) 单 击 “ 确 定 ” 按 钮 ,将 Index. html 文件 和 ex. css 文件 进行 关联 ,关联 后 的 “CSS 样 
式 " 面 板 如 图 6-41 所 示 。 









链接 外 部 样式 表 



































文件 /URLGE): css/ex. css ”6 框 二 
添加 为 回 链接 () 
旧 导 入 四 
捍 体 中: 
您 也 可 以 输入 逗号 分 隔 的 媒体 类 型 列表 。 
Dreamweaver 的 范例 样式 去 可 以 帮助 您 起 步 * 








图 640 “链接 外 部 样式 表 " 对 话 杠 图 6-41 关联 后 的 “CSS 样式 "面板 


(5) 按照 例 6. 10 的 第 (8) ~ (10) 步 操作 。 

如 果 同 一 个 HTML 元 素 定义 了 多 个 样式 ,通常 所 有 的 样式 会 根据 优先 级 层 全 于 一 个 
新 的 虚拟 样式 表 中 ,它们 的 优先 级 为 : 标签 内 样式 表 优 先 级 最 高 ;其 次 是 内 部 样式 表 ; 再 
次 是 外 部 样式 表 ; 最 后 是 浏览 器 的 默认 设置 。 


习 题 


一 、 填空 题 

1. HTML 的 中 文 称 为 。 _, 用 于 描述 超 文本 中 内 容 的 显示 方式 。 

2. 网 页 是 由 文字 、 图 片 . 动 画 、 声 音 和 视频 等 多 种 媒体 信息 以 及 链接 组 成 的 ,其 中 
中 、@ 及 @ 是 构成 一 个 网 页 的 三 种 基本 元 素 ,通过 @ 可 以 实现 与 其 他 网 
页 或 网 站 的 关联 和 跳 转 。 

3. 单 击 “编辑 "菜单 一 ”选项 ,在 弹出 的 对 话 框 中 可 以 配置 系统 环境 ,以 满足 个 性 
化 的 要 求 。 

4. Dreamweaver CS5 的 工作 界面 由 四 、@ @  、 dg  、 @ 、@O 
和 _@ 等 部 分 组 成 。 

5. 在 Dreamweaver 中 ，Q@ 是 一 个 管理 各 种 网 页 文件 的 场所 ,由 一 系列 文件 组 合 而 
成 ,这 些 文件 拥有 相似 的 属性 或 实现 相同 的 目的 ,可 以 设置 四 和 ”@ 两 种 文件 夹 。 
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6. HTML 标签 分 为 “中 和 @@。 其 中 对 标签 由 @ 和 @ 组 成 。 

7. HTML 单 标签 只 有 标签。 

8. 一 个 HTML 文档 中 中 是 HTML 文档 的 头 部 标签 ， @， 标签 用 于 定义 页 面 的 
标题 ， @) 标签 用 于 指明 文档 的 主体 区 域 。 

9. 设置 网 页 文档 内 容 的 可 见 部 分 ,开始 标签 是 _Q@ ,结束 标签 是 @ 四 。 

10. 大 多 数 浏览 器 默认 的 背景 颜色 为 白色 ,使 用 < Body > 标签 的 _@ 属性 可 以 为 
整个 网 页 定义 背景 颜色 ;_@ 属性 将 图 像 作为 网 页 的 背景 ;_@@ 属性 为 网 页 设置 文本 
的 颜色 。 

11. 在 网 页 中 插入 背景 图 像 ,文件 的 路 径 及 名 称 为 /img/bg. jpg,HTML 语句 是 。 

12. 在 文档 窗口 中 输入 一 段 文 字 后 按 “@ _ 键 , 这 段 文字 就 形成 一 个 段落 ,内 容 包 含 
在 _@ 标签 中 。 

13. 使 用 文本 格式 化 标签 可 以 对 HTML 中 的 文字 进行 格式 化 ， 中 “标签 使 文字 加 
粗 、@， 标签 使 文字 倾斜 、 加 “标签 使 文字 加 下 画 线 、 四 “标签 使 文字 加 删除 线 。 

14. 图 像 是 网 页 构成 的 重要 元 素 之 一 ,HTML 中 插入 图 像 的 标签 是 。 

15. ”就 是 单 击 网 页 中 某 一 幅 图 像 后 ,浏览 器 将 链接 到 另 一 幅 图 像 或 另 一 个 页 面 。 

16. CSS 选择 器 包含 类 型 说 明和 名 称 ,其 中 类 型 说 明 主要 有 中 、@ 














和 @ 。 
17. 定义 类 选择 器 时 ,在 类 名 称 前 面 加 一 个 QD _ ;定义 Id 选择 器 时 ,在 类 名 称 前 面 
加 一个 _@@ ， 
18. 在 使 用 link 元 素 调用 CSS 外 部 样式 表 中 ， _ 属性 是 用 来 指定 CSS 文件 的 路 径 。 
二 、 单 选 题 
1. ) 的 中 文 称 为 超 文本 标记 语言 。 
A. HTTP B. DIV C. HTML D. CSS 
2. 在 Dreamweaver 中 ,下 面 ( ) ,可 以 打开 “插入 "面板 。 
A.“ 文 件 "菜单 一 “新 建 " 选 项 B.“ 窗 口 "菜单 一 “插入 "选项 


C.“ 插 入 "菜单 一 “布局 对 象 " 选 项 D.“ 插 入 "菜单 一 “创建 面板 "选项 
3. HTML 文件 标题 标签 是 ( )。 


A. <HTIML > B. < Head > C. < Hitle > D. < Body > 
4. 标签 是 HTML 文档 的 主要 组 成 部 分 ,都 括 在 一 对 ( 。 “”) 中 。 
A. 小 括号 B. 双 引 号 C. 方 括号 D. 尖 括 号 


5. HTML 的 配对 标签 由 起 始 标签 和 结束 标签 组 成 ,起 始 标签 一 般 使 用 ” < 标签 名 称 > "来 
表示 ,而 结束 标签 在 起 始 标签 前 多 了 一 个 (  )。 
A. 竖 线 | B. 星 号 * C. 小 于 号 < D. 和 斜 杠 / 
6. 下 列 关于 HTML 属性 说 法 错误 的 是 ( Ks 
A. HTML 属性 包括 属性 名 和 属性 值 
B. HTML 元 素 可 以 有 多 个 属性 ,它们 之 间 没 有 前 后 顺序 之 分 
C. HTML 属性 值 最 好 包含 在 英文 半角 的 双 引 号 中 
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D. HTML 属性 可 以 在 元 素 的 结束 标签 中 规定 
7. 按 下 ( ) 键 可 以 将 网 页 置 于 浏览 器 中 进行 测试 预览 。 
A. FI11 B. F12 C. F3 D. F6 
8. 下 列 关于 HTML 定义 链接 文本 颜色 说 法 错误 的 是 ( Nis 
A. Link 属性 是 未 访问 的 链接 颜色 
B. Alink 属性 是 活动 链接 的 颜色 
C. Vlink 属性 是 访问 过 的 链接 颜色 
D. 网 页 中 未 访问 的 链接 颜色 默认 为 红色 
9. 用 属性 面板 设置 图 像 链接 时 ,目标 列表 的 (中 ) 选 项 将 链接 的 对 象 在 该 链 
接 所 在 的 同一 框架 或 窗口 中 打开 ;(_@， ) 选 项 是 将 链接 的 对 象 在 整个 浏览 器 窗口 中 打 
开 ;(_ 国 _) 选 项 是 将 链接 的 对 象 在 含有 该 链接 的 框架 的 父 框架 集 或 父 窗口 中 打开 。 











A. _Blank B. _Parent C. _Self D. _Top 
10. 要 在 新 窗口 中 显示 链接 页 面 ,应 在 (ay 标签 中 设置 ( ) 属 性 。 

A. Target B. Href C. Alink D. Vlink 
11. 在 HTML 中 ,下 面 ( ) 标 签 在 标记 的 位 置 强制 换行 。 

A. <HIl > B. <P> C. <BR> D. <HR> 


12. 关于 网 页 中 的 换行 ,说 法 错误 的 是 ( )。 
A. 在 HTML 代码 中 按 Enter 键 ,网 页 中 的 内 容 也 会 换行 。 
B. 使 用 <br > 标签 可 以 换行 。 
C. 使 用 <p > 标签 可 以 换行 。 
D. 用 <br > 标签 换行 , 行 间 没有 间隔 ;使 用 <p > 标签 换行 , 行 间 有 间隔 。 
13. 在 HTML 中 ,可 以 使 用 ( ) 标 签 向 网 页 中 插入 GIF 动画 文件 。 
A. <IMC > B. < Body > C. <Table > D. < Form > 
14. 在 HTML 中 ,可 以 通过 设置 < Font > 标签 的 ( ) 属性 值 ,来 设置 文本 的 字体 





A. Style B. Size C. Color D. Face 
15. 在 HTML 文件 中 ,将 <img > 标签 放 在 ( ) 标签 之 间 ,这 幅 图 像 就 变 为 一 幅 可 
单 击 的 图 像 链 接 。 
A. <Link > … </Link > B. <a>…</a> 
C. <Font>:… </Font > 了 <pS"<7Zp> 
16. 在 HTML 中, 下列 选项 关于 <IMG > 的 sre 属性 说 法 正确 的 是 ( )。 
A. 用 来 设置 图 片 文件 的 格式 
B. 用 来 设置 图 片 文件 所 在 的 位 置 
C. 用 来 设置 鼠标 指向 图 片 时 显示 的 文字 
D. 用 来 设置 图 片 周围 显示 的 文字 
17. 关于 下 列 两 行 HTML 代码 , < img src =" image. gif" alt ="picture" > 和 <a href 
="image. gif" > picture </a > ,说 法 正确 的 是 ( a 
A. 两 者 都 是 链接 到 图 片 
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26 


27 
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B. 前 者 是 链接 到 ,后 者 是 在 网 页 中 直接 显示 图 片 

C. 两 者 都 是 在 网 页 中 直接 显示 图 片 

D. 前 者 是 在 网 页 中 直接 显示 图 片 ,后 者 是 链接 到 图 片 
. 关于 <IMG border ="15" Src = "EE:\MySite\Image\Maple. jpg " Alt = "正在 加 载 
Width ="458" ”Height = "336" /> 代码 片段 的 说 法 中 ,错误 的 是 ( ji 

A. Border 是 图 像 边框 宽度 

B. Height 是 指 图 像 显示 时 的 高 度 

C. Sre 是 指 图 像 的 Un 路 径 

D. Alt 是 鼠标 移动 到 图 像 上 时 的 提示 文字 





. 在 HTML 中 ,用 文本 格式 化 标签 可 以 对 HTML 中 的 文字 进行 格式 化 ,(”Q@ ) 标 
字 上 标 显示 .(_@， ) 标 签 使 文字 下 标 显示 、(”@ ) 标 签 使 文字 大 字体 显示 。 
A. <Sub> B. <Small> C. <Big> D: <SupS> 
. HTML 文件 段落 标签 是 (。”)。 
4 B: <bs CG. hls D. <Font> 
. 单 击 网 页 中 ( ) 会 跳 转 到 当前 页 面 的 某 个 位 置 。 
A. 空 链 接 B. 文本 链接 C. 锚 记 链接 D. E-mail 链接 
. 跳 转 到 当前 页 面 的 “bn” 锚 点 的 代码 是 ( )。 
A Calrefs=™" ha >... aS B: ef 三 "Da Sec /a 
CC. <n hrefs "i SS 0. <Aa> D. <abhref="9%bi" > </a> 


. 下 列 选项 中 ( ) 可 以 打开 邮件 客户 端 程序 。 
A. <a href ="mailto:lx@163. com" > 联系 我 们 </a> 
B. <a href ="http://lx@ 163.com" > 联系 我 们 </a> 
C.， <a name =" lx@ 163. com " > 联系 我 们 </a> 
D，<a href = " 枚 x@ 163. com " > 联系 我 们 </a > 

. 下 列 选项 中 ( ) 是 绝对 路 径 。 
A. http://www. sohu. com/ index. html 
B. information/temp. html 
C. temp. html 
D. ../information/temp. html 





. 在 设计 视图 下 , 单 击 ( 。””) 菜 单一 “媒体 "一 "SWF” 选 项 ,可 以 将 SWF 动画 添加 
中 。 
A. 编辑 B. 插入 C. 修改 D. 窗口 
. HTML 中 ( ) 可 以 定义 内 赂 样式 表 。 
A. Style 标签 B. Style 属性 C. Styles 标签 D. Class 属性 
. HTML 中 ( ) 标 签 用 来 定义 内 部 样式 表 。 
A. <Style> B. <CSS> C. <Script> D. <CSSStyle > 


. 下 列 选项 中 定义 外 部 样式 表 正确 的 是 (。”)。 


A. <stylesheet > mystyle. css </stylesheet > 
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29. 


B. <link rel="stylesheet" type ="text/css" src ="mystyle.css" > 
C. <link rel ="stylesheet" type ="text/css" href =" mystyle. css" > 
D. < stylesheet href ="mystyle. css" > 


定义 了 下 面 ( ) 样 式 规则 后 ,可 以 使 用 <P Id ="fp" > 这 是 一 个 段落 </P >， 


将 该 样式 应 用 于 网 页 上 的 某 个 段落 。 


A. <Style Type ="Text/Css" > P|Color:Blue! </Style > 

B. <Style Type ="Text/Css" > #fp| Color: Blue! </Style > 
C. <Style Type ="Text/Css" > .fp| Color: Blue! </Style > 
D. <Style Type ="Text/Css" > P.fp|Color: Blue! </Style > 
下 面 ( 


30. ) 几乎 可 以 控制 所 有 网 页 中 文字 的 属性 ,也 可 以 应 用 到 整个 网 站 的 所 
有 网 页 上 。 
A. CSS 样式 B. HTML 样式 
C. 页 面 属性 D. 文本 属性 面板 
31. 在 HTML 文档 中 ( ) 适 合 引用 外 部 样式 表 。 
A. 在 <Head > 部 分 B. 文档 结尾 
C. 文档 开始 D. 在 <Body > 中 
32. 定义 CSS ,下 列 选项 中 ( ) 将 所 有 Hl 的 背景 颜色 定义 为 白色 。 
A. all. Hl | background-color:#EFFFFFF 
B. HI | background-color:#FFFFFTF | 
C. HI1. all | background-color:#FFFFFTF | 
D.Hl#tall | background-color:#EFFFFFF | 
33. 定义 CSS, 下 列 选项 中 ( 。 ”) 将 所 有 P 的 字体 定义 为 bold。 


A. <P style = "text-size:bold" > 
C. Pjitext-size:bold | 


B. <P style ="font-size:bold" > 
D. P|font-weight: bold| 


B. style:bold 
D. font:bold 


34. 定义 CSS, 下 列 选项 中 ( ) 用 来 设置 字体 大 小 。 
A. font-weight :bold 
C. font :12px 
35. 关于 #menu | font-size :14px;| 的 描述 正确 的 是 ( ss 





A. menu 是 标签 选择 器 
C. menu 是 类 选择 器 


三 、 多 选 题 

1. 编辑 文档 时 有 ( ) 视 图 方式 。 
A. 代码 B. 页 面 
D. 设计 E. 拆 分 

2. 浮动 面板 组 中 包含 的 面板 有 ( hs 
A. CSS 样式 面板 ” B. 应 用 程序 面板 
D. 文件 面板 E. 资源 面板 


B. menu 是 元 素 选 择 带 
D. menu 是 ID 选择 器 


C. 插入 面板 
F. 代码 检查 器 面板 
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3. Dreamweaver 中 ,站 点 分 为 ( > 
A. 局 域 文件 夹 B. 广 域 文件 夹 C. 本 地 文件 夹 
D. 测试 文件 夹 E. 远程 文件 夹 
4. 关于 HTML 语言 下 列 说 法 正确 的 是 ( Ye 
. HTML 是 HyperText Markup Language 的 首 字母 缩写 
. HTML 文件 中 可 以 插入 图 形 声音 ,视频 等 多 媒体 信息 
. HTML 文件 中 可 以 建立 链接 
. HTML 是 纯 文 本 类 型 的 语言 ,可 以 使 用 任何 文本 编辑 器 打开 查看 ,编辑 


[一 


. HTML 文件 中 只 能 创建 文字 、 图 形 和 链接 


5. HTML 文件 是 由 ( ) 构成 。 
A. HTML 标题 B. HTML 标签 C. HTML 元 素 
D. HTML 属性 E. HTML 值 

6. 下 列 关 于 HTML 文档 说 法 错误 的 是 ( ye 


A. 


二 :人 罗 





一 个 网 页 对 应 一 个 文档 , 超 文 本 标签 语言 文档 的 扩展 名 为 HTML 或 HTM 


. HTML 文档 不 是 纯 文本 文件 
. HTML 文档 只 能 由 Dreamweaver 生成 ,不 能 用 记事 本 编辑 
. HTML 文档 中 的 尖 括 号 ,标签 .属性 项 等 必须 使 用 半角 的 西 文字 符 


HTML 文档 的 列 宽 不 受 限制 ,多 个 标签 可 写成 一 行 


7. 下 面 选项 中 说 法 正确 的 是 ( )。 


户口 虽 只 和 


<! DOCTYPE > 必须 写 在 HTML 文档 的 第 1 行 ,位 于 < Html > 标签 之 前 
<meta > 标签 可 提供 搜索 引擎 的 关键 

<meta > 标签 位 于 <head > … </head > 内 

<meta> 有 对 应 的 结束 标签 

<! DOCTYPE > 用 于 声明 文档 类 型 ,不 是 HTML 标签 


: 半 使 用 Dreamweaver 创建 网 站 的 叙述 ,正确 的 是 ( )s 


外 


站 点 的 命名 最 好 用 英文 或 英文 和 数字 组 合 
网 页 文件 应 按照 分 类 分 别 存 入 不 同文 件 夹 
必须 首先 创建 站 点 ,网 页 文件 才能 够 创建 
静态 文件 的 默认 扩展 名 为 . htm 或 . html 
首页 的 文件 名 必须 是 index. html 


9. 下 列 选 项 中 ( ) 一 般 作为 网 站 首页 的 名 称 。 
A. index B. default C. about 
D. news E. first 
10. 使 用 ( ) 属 性 可 以 设置 网 页 中 链接 文本 的 相关 颜色 。 
A. LinkColor B. Link C. BgColor D. BLink 
E. ALink F. VLink 
11. 在 HTML 中, 下面 ( ””) 属 于 HTML 文档 的 基本 组 成 部 分 。 
A. <Style > </Style > B. <Body > </Body > 
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12; 


13: 


C. <HIML> </HTML > D. < Head > </Head > 

E. <File> </File> 

以 下 说 法 正确 的 是 ( js 

A. < HTML > 标签 应 该 以 </HTML > 标签 结束 

B. < BR > 标签 应 该 以 </BR > 标签 结束 

C. < Title > 标签 应 该 以 </Tite > 标签 结束 

D. < HR > 标签 应 该 以 </HR > 标签 结束 

EE. < Font > 标签 应 该 以 </Font > 标签 结束 

要 在 网 页 中 显示 “欢迎 访问 我 的 主页 1" 文 本 ,要 求 字 体 类 型 为 隶书 ,字体 大 小 为 


6, 则 下 列 HTML 代码 正确 的 是 ( We 


<p> <Font Size =6 Type = "隶书 " > 欢迎 访问 我 的 主页 ! </Font> 
<p> <Font Size = +6 Face = "隶书 " > 欢迎 访问 我 的 主页 ! </Font > 
<p> <Font Size =6 Face =" 隶 书 " > 欢迎 访问 我 的 主页 ! </Font > 
<p> <Font Size = +3 Style = "隶书 " > 欢迎 访问 我 的 主页 ! </Font > 
E. <p> <Font Size = +3 Face =" 隶 书 " > 欢迎 访问 我 的 主页 ! </Font> 


已 P 只 > 


. 用 属性 面板 设置 图 像 链 接 时 ,目标 "列表 的 ( ) 选 项 功能 相同 。 


A. _Blank B. _Parent C. _Self 
D. _Top E. _New 


. 对 < HR Size = "5" Color = "#0000FF"” Width ="50%" > 的 说 法 中 ,( ) 


A. Size 是 指 水 平 线 的 长 度 B. Size 是 指 水 平 线 的 高 度 
C. Width 是 指 水 平 线 的 宽度 D. Width 是 指 水 平 线 的 高 度 
E. Color 是 指 水 平 线 的 位 置 F.Color 是 指 水 平 线 的 颜色 





. 关于 链接 ,下 列 选项 中 ( ) 是 正确 的 。 


A. 链接 可 以 应 用 在 文本 上 也 可 以 应 用 在 图 像 上 

B. 链接 使 网 页 之 间 具有 跳 转 的 能 力 ,使 浏览 者 可 以 不 需要 顺序 阅读 
C. 链接 只 能 用 来 链接 到 本 页 面 的 其 他 位 置 

D. <A > 标签 的 sre 属性 用 于 指定 要 链接 的 地 址 

E. 链接 只 能 在 不 同 的 网 页 之 间 进 行 跳 转 


. 创建 到 锚 记 的 链接 的 过 程 分 为 ( 。” ”) 两 步 。 


A. 创建 锚 记 向 导 “B. 设置 链接 类 型 ” C. 创建 命名 锚 记 
D. 设置 链接 状态 E. 创建 到 命名 锚 记 的 链接 


. 关于 绝对 路 径 的 使 用 ,以 下 说 法 错误 的 是 ( ) 。 





A. 使 用 绝对 路 径 的 链接 不 能 链接 本 站 点 的 文件 ,要 链接 本 站 点 文件 只 能 使 用 相 
对 路 径 。 

B. 绝对 路 径 是 指 包括 服务 器 规范 在 内 的 完全 路 径 ,通常 用 http:// 表 示 

. 绝对 路 径 不 管 源 文件 在 什么 位 置 都 可 以 非常 精确 地 找到 

D. 当 引 用 当前 站 点 以 外 的 文件 时 通常 使 用 绝对 路 径 


到 
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E. 应 当 尽 量 使 用 绝对 路 径 ,避免 使 用 相对 路 径 

19. 关于 路 径 说 法 正确 的 是 ( )'s 
A. 直接 写 文件 名 或 文件 名 前 加 “./" 表 示 当 前 目录 
B. 直接 写 子 目录 名 和 “/” 表 示 当 前 目录 下 的 子 目录 
C.“../”" 表 示 前 级 目录 
D.“/" 开 始 的 路 径 表 示 从 站 点 主 目录 开始 
E. 创建 设计 链接 前 ,应 该 保存 当前 网 页 文件 ,以 便 确定 相对 路 径 的 起 始 位 置 

20. 已 知 index. html 与 文件 夹 information 在 同一 个 服务 器 的 根 目录 下 ,ser. html 在 文 

件 夹 information 中 ,车 在 text. html 中 添加 链接 ,链接 到 ser. html ,下 列 语句 正确 的 是 ( 
) 。 





A. <A Href = "ser. html" > 链接 </A > 
B. <A Href ="information/ser. html" > 链接 </A > 
C. <A Href ="../information/ser. html" > 链接 </A > 
D. <A Href ="./ser.html" > 链接 </A> 
E. <A Href ="/information/ser. html" > 链接 </A> 
21. 下 列 CSS 语法 规则 错误 的 是 ( )。 
A. body:color = black B. |body;color:black! 
C. body|color: black | D. |body:color = black! 


E. body |color;black| 
22. 下 列 选项 中 ( ) 不 属于 CSS 文本 属性 。 


A. Font-Size B. Text-Decoration 
C. Text-Align D. line-height 
E. Font-Family F. Font-Color 


23. 有 一 样式 表 规则 : H3 | color:blue;font-size:10pt| ,下 列 说 法 正确 的 是 ( )。 
A. H3 是 选择 器 B. blue 是 属性 C. 样式 表 中 的 冒号 ( : ) 可 以 用 = 替代 
D. color 是 属性 值 E. font-size 是 属性 
24. 在 CSS 层 秋 样式 表 中 有 ( ) 选择 器 。 
A. 标记 选择 器 。 B. 属性 选择 器 C. 样式 选择 器 
D. ID 选择 器 E. 类 选择 器 
25. 下 列 关于 外 部 样式 表 的 说 法 ( ) 是 正确 的 。 
A. 文件 扩展 名 为 . CSS 
B. 外 部 样式 表 内 容 不 需要 使 用 <style> 标签 
C. 用 <link > 标签 引入 外 部 样式 
D. 用 外 部 样式 表 可 以 使 网 站 更 加 简洁 ,风格 保持 统一 
E. 用 外 部 样式 表 可 以 实现 网 页 HTML 与 CSS 代码 的 分 离 
26. 关于 CSS 基本 语法 说 法 正确 的 是 ( )e 





A. 声明 要 包含 在 | | 号 之 中 B. 属性 和 属性 值 之 间 用 等 号 连接 
C. 每 条 声明 是 由 属性 和 值 组 成 D. 选择 器 包含 类 型 说 明和 名 称 
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E. 属性 和 属性 值 之 间 用 冒号 连接 
27. 关于 CSS 的 CLASS 和 ID 说 法 ,正确 的 是 ( hs 

A. 定义 class 选择 器 的 格式 为 # 类 名 | 样式 | 
. 应 用 id 选择 器 的 格式 为 < 指定 标签 id ="id 名 " > 
.应 用 class 选择 器 的 格式 为 < 指定 标签 class = "类 名 " > 
定义 id 选择 器 的 格式 为 .类 名 | 样式 | 
id 选择 器 和 class 选择 器 没有 任何 区 别 





刀口 中 史 


. 什么 是 HTML? 

. 站 点 的 功能 是 什么 ?本 地 文件 夹 与 远程 文件 夹 有 什么 区 别 ? 
. Dreamweaver 设计 网 页 应 该 采用 哪些 步骤 ? 

. 链接 的 功能 有 哪些 ? 

. 如何 创 建 CSS? 


ni 上 mmPDBD 一 
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随 着 互联 网 技术 的 发 展 ,网 页 已 经 发 生 了 较 大 变化 ,由 文字 和 图 片 简 单 堆 秋 出 来 的 网 
页 通常 页 面 元 素 风 格 单调 ,结构 混乱 ,难以 吸引 用 户 的 关注 。 因 此 ,设计 网 页 时 需要 规划 
网 页 的 布局 ,内容 和 样式 ,再 充分 利用 模板 提高 网 页 的 设计 效率 。 这 些 都 属于 静态 网 页 设 
计 的 内 容 。 

设计 专业 的 静态 网 页 需要 解决 下 列 问 题 : 

(1) 网 页 常见 的 布局 类 型 有 哪些 ? 各 自 有 什么 特点 ? 

(2) 实现 网 页 布局 的 方式 有 哪些 ? 具体 设计 流程 是 什么 ? 

(3) 如 何 使 用 表单 和 Spry 控件 设计 交互 性 网 页 ? 

(4) 如 何 使 用 模板 实现 网 页 的 快速 设计 和 更 新 ? 


7.1 网 页 布局 设计 


网 页 布局 就 是 对 页 面 中 的 文字 、 图 片 .多 媒体 对 象 和 表格 进行 统一 的 样式 和 位 置 设 
计 。 在 设计 网 页 内 容 之 前 ,根据 网 站 的 类 型 定位 , 按 多 数 访问 者 的 浏览 习惯 或 约定 俗 成 的 
标准 ,明确 网 页 包含 的 网 站 标志 、 导 航 栏 菜单 和 正文 信息 等 内 容 的 摆 放 位 置 ,对 页 面 进行 
整体 规划 ,使 得 网 站 中 的 所 有 页 面 风格 统一 ,重点 突出 。 


7.1.1 常见 网 页 版 面 布局 类 型 


网 页 通常 由 标题 .脚注 . 侧 栏 和 正文 等 页 面 区 域 组 成 。 在 不 同 布局 模式 下 其 位 置 和 大 
小 可 能 不 同 ,一 般 来 说 ,重要 元 素 应 该 摆 放 在 突出 位 置 。 此 外 ,充分 利用 Flash 动画 技术 ， 
会 使 网 页 内 容 更 丰富 多 彩 。 网 页 布局 大 致 可 以 分 为 “ 国 " 字 形 “ 厂 "字形 “三 ”字形 、 标 
题 正文 型 框架 型 封面 型 和 Flash 型 几 个 类 别 。 

在 设计 具体 网 页 之 前 ,首先 要 根据 网 站 类 型 和 当前 网 页 的 作用 选择 网 页 的 布局 。 
下 面 以 设计 一 个 中 小 型 人 才 招 聘 网 站 为 例 ,说 明 不 同 布局 类 型 的 特点 和 适用 的 业务 
范围 。 





1.“ 国 ”字形 布局 


这 种 布局 分 标题 区 . 左 侧 栏 中间 内 容 区 , 右 侧 栏 和 脚注 区 ,类 似 * 国 " 字 , 称 为 " 国 "字形 
布局 。 页 头 是 网 站 的 标志 和 广告 条 等 ;中 间 内 容 区 是 网 页 主体 内 容 ;左右 栏 用 于 放置 图 片 或 
文字 链接 的 导航 和 工具 栏 等 ;页 脚 是 网 站 的 基本 信息 和 版 权 声 明 等 内 容 , 如 图 7-1 所 示 。 
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图 7-1 “ 国 " 字 形 布局 


“ 国 "字形 布局 能 够 充分 利用 版 面 , 信 息 量 大 ,链接 多 ,适合 信息 分 类 繁多 的 大 型 商业 
门户 网 站 ,但 是 页 面 拥挤 。 如 果 组 织 不 好 ,会 对 用 户 造 成 视觉 混乱 。 


2.“ 厂 ”字形 布局 

这 种 布局 分 标题 区 、 左 侧 栏 .中间 内 容 区 和 脚注 区 ,也 称 “拐角 型 "布局 。 与 “ 国 " 字 形 
布局 不 同 的 是 : 去 掉 了 “ 国 " 字 形 布局 的 右 侧 栏 , 左 侧 栏 主要 提供 网 站 导航 功能 ,为 中 间 正 
文 内 容 区 提供 了 更 大 的 版 面 空 间 。“ 厂 ”字形 布局 是 一 种 常见 的 网 页 布局 ,页 面 结构 清 
晰 、 主 次 分 明 , 比 较 适合 机 构 . 企 事 业 单 位 的 公司 网 站 ,例如 人 才 招 聘 网 站 。 

3.“ 三 ”字形 布局 


这 种 布局 只 含 标 题 区 、 内 容 区 和 脚注 区 ,是 一 种 简洁 明快 的 网 页 布局 。 主 要 特点 是 : 
页 头 与 页 脚 由 两 条 横向 色 条 组 成 ,将 网 页 整体 分 割 为 3 部 分 。 上 下 色 条 中 大 多 放 曾 网 站 
信息 .广告 和 版 权 提示 等 。“ 三 "字形 布局 页 面 精简 ,突出 显示 网 站 中 的 主体 内 容 , 适 合用 
作 人 才 招 聘 网 站 中 具体 岗位 信息 页 面 的 布局 。 


4. 标题 正文 型 布局 


这 种 布局 最 上 面 是 通用 的 标题 .网 站 标志 和 导航 条 ,下 面 是 网 页 正文 部 分 。 标 题 正文 
型 布局 由 于 页 面 简单 明了 ,重点 突出 ,访问 速度 快 ,所 以 适合 搜索 引擎 类 网 站 ,也 可 以 用 作 
人 才 招 聘 网 站 中 论坛 页 面 或 注册 页 面 的 布局 。 


5. 框架 型 布局 
框架 型 布局 将 网 页 分 为 多 个 子 页 面 ,每 个 子 页 面 拥有 独立 的 显示 内 容 和 滚动 条 。 杠 
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而 


架 型 布局 分 为 左右 框架 型 和 上 下 框架 型 ,一 个 框架 是 导航 链接 , 另 一 个 框架 是 正文 信息 。 
浏览 网 页 时 ,导航 条 子 页 面 内 容 通 常 不 变 ,通过 导航 条 的 链接 刷新 正文 内 容 ,如 图 72 所 
示 。 常 用 于 具有 多 个 导航 的 网 页 ,例如 论坛 网 站 。 








人 meds, maserexf: 
RW)Job [可 技 作 ] 5 六 区 Sa 于 
EE ssxwnnaymawm uasm aaserassrm cu am 
ea 


EE 





or 时 机 联合 汽车 电子 有 限 公司 2015 术 加 澡 得 (请 字 硕 呐 ) 
各。 于 本 女 第 十 一 层 交 业 慑 务 只 纳 疡 遂 知 

吉 。 时机 第 十 一 届 业 服务 容纳 新 通知 

5 量 了 D 妇 第 十 一 帮 名 业 有 务 队 纳 新 宣讲 会 

ist (而 现时 唐 达 2015 年 机 加 要 阳 

9 于 阳 太 2014-2015 学 年 吉林 大 学 毕业 生 就 业 指导 中 心 综合 作 .… 
1 晶 本 吉林 大 学 第 一 医院 操 肝 2014 年 时 务 、 工 程 、 图 书 人 
7 从中 本 字 雪 

3 技 本 软 志 加 i 节 长 小 

< 诚 放 朱子 家 雪 

atl 总 尖 家 孝 

本。 表 林 大学 研 二 永吉 

Ts 寺 大 怕 友 的 刘 约 件 公司 招聘 可 庆 员 


图 7-2 框架 型 布局 














6. 封面 型 布局 


这 种 布局 在 页 面 中 使 用 大 幅 图 片 ,配合 简洁 的 文字 进行 排版 ,页 面 中 文字 很 少 ,往往 
是 图 片 加 上 简单 的 “进入 "或 “登录 "链接 ,简单 明了 ,整洁 漂亮 。 

封面 型 布局 需要 精心 设计 ,才能 突出 主题 ,吸引 用 户 , 多 用 于 企业 展示 型 网 站 的 首页 
或 个 性 类 网 站 的 登录 页 面 。 


7. Flash 型 布局 


这 种 布局 通过 舱 入 Flash 动画 实现 页 面 导航 和 页 面 展 示 , 布 局 灵活 ,表现 形式 多 样 。 
由 于 Flash 功能 完整 且 适 合 网 络 应 用 ,可 以 为 用 户 提供 更 好 的 视听 享受 ,相对 于 封面 型 布 
局 ,这 种 页 面 更 绚丽 有 趣 ,具有 交互 性 ,能 吸引 用 户 的 关注 。 但 是 ,如 果 整 个 网 页 都 用 
Flash 制作 , 则 可 能 有 兼容 性 问题 , 下 载 时 间 会 长 ,不 适合 包含 大 量 文本 内 容 的 网 站 。 

设计 网 页 时 ,可 以 根据 实际 情况 选择 网 页 布局 。 例 如 页 面 内 容 多 ,就 用 * 国 "字形 或 
“三 "字形 ;页 面 内 容 是 一 些 简单 的 说 明 性 文本 ,就 用 标题 正文 型 ;希望 浏览 方便 ,速度 快 ， 
不 需要 结构 变化 ,就 用 框架 型 ;要 展示 企业 或 个 人 形象 ,封面 型 是 首选 ;Flash 型 页 面 动态 
感 强 , 更 具 交 互 性 ,但 不 宜 表达 过 多 的 文字 信息 。 


7.1.2 使 用 Dreamweaver 预 设 布 局 


制作 网 页 时 有 很 多 影响 网 页 布局 的 因素 , 导致 从 零 开 始 创建 会 比较 烦琐 
Dreamweaver 提供 了 一 些 预 设 网 页 布局 ,合理 地 使 用 这 些 布局 会 简化 网 页 设计 的 流程 。 

依据 预 设 网 页 布局 创建 网 页 文档 的 方法 是 : 单 击 “文件 "菜单 一 “新 建 " 选 项 ,打开 
“新 建文 档 ” 对 话 框 ,如 图 7-3 所 示 。 从 “页 面 类 型 "列表 中 选择 “HTML”,“ 布 局 "列表 中 
选择 一 种 预 设 布局 ( 右 窗 格 显示 布局 说 明和 预览 图 ) , 单 击 “ 创 建 "按钮 。 
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图 7-3 ”Dreamweaver 中 预 设 布局 选项 


单 击 “ 获 取 更 多 内 容 " 链 接 , 可 以 在 官方 网 站 上 下 载 更 多 的 布局 类 型 。 在 预 设 布局 
中 , 侧 栏 和 正文 宽度 分 为 “ 列 固定 "和 *“ 列 液态 "两 种 类 型 。“ 列 液态 "类 型 表示 以 浏览 器 
宽度 的 百分比 (% ) 定 义 区 域 列 宽 , 当 改变 浏览 器 尺寸 时 ,会 自动 调整 区 域 的 列 宽 。“ 列 固 
定 " 类 型 以 像素 数量 定义 区 域 列 宽 ,区 域 宽度 不 会 随 浏览 器 的 尺寸 而 变化 。 


7.2 Div 元 素 及 CSS 布局 


实现 网 页 布局 主要 有 框架 .表格 和 CSS 布局 3 种 技术 。 其 中 CSS 布局 使 用 模块 化 的 
思想 设计 网 页 ,首先 在 < Body > 元 素 内 定义 多 个 可 艇 套 的 < Div > 元素 ,将 页 面 内 容 分 割 
成 多 个 相对 独立 的 区 域 ,再 使 用 CSS 定义 每 个 区 域 的 尺寸 位置 和 颜色 等 显示 样式 。 

由 于 CSS 代码 通常 定义 在 < Head > 元 素 内 或 者 生成 独立 的 CSS 文件 ,网 页 的 内 容 和 
样式 相 分 离 ,使 得 代码 更 简洁 , 调 高 了 网 页 的 访问 速度 ,降低 了 维护 难度 ,因此 CSS 布局 
已 成 为 网 页 设计 中 的 主流 布局 方式 。 


7.2.1 CSS 的 定位 机 制 


HTML 规范 中 将 HTML 元 素 分 成 块 元 素 ( Block Element) 和 内 联 元 素 ( Inline Element) 
两 种 显示 模式 , 块 元 素 独立 占 行 ,如 <P > 元 素 ;内 联 元 素 不 独占 行 ,如 < B > 元 素 。 标 准 
的 HTML 布局 通过 文档 流 机 制 进行 显示 : 浏览 器 按照 文档 中 HTML 元 素 的 书写 顺序 , 根 
据 元 素 的 显示 模式 在 窗口 中 将 元 素 从 上 到 下 ,从 左 到 右 依次 呈现 到 页 面 上 。 

CSS 提供 了 一 些 更 改元 素 显 示 位 置 的 属性 ,利用 这 些 属性 可 以 使 元 素 脱 离 文档 流 的 
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默认 限制 。CSS 有 三 种 基本 的 元 素 定位 机 制 : 普通 流 .浮动 和 定位 。 
(1) 普通 流 。 元 素 的 位 置 由 文档 流 的 位 置 决定 ,可 以 通过 CSS 的 Display 属性 将 页 面 





元 素 设 壮 为 块 元 素 或 内 联 元 素 。 
(2) 浮动 。 元 素 在 水 平方 向 向 浏览 器 窗口 边缘 浮动 ,周围 的 其 他 元 素 会 重新 排列 ,可 


以 通过 设置 CSS 的 float 属性 实现 。 


(3) 定位 。 让 元 素 相对 其 文档 流 位 置 .网 页 甚至 浏览 
Position 属性 设置 定位 方式 ,并 借助 Left .Right \Top 和 Bottom 属性 确定 位 置 。 


CSS 的 布局 属性 如 表 7-1 所 示 。 


表 7-1 CSS 的 布局 属性 说 明 


窗口 确定 显示 位 置 ,CSS 通过 





























属性 DW 类 别 属性 值 说 明 例子 

Block 显示 为 块 元 素 

Display 区 块 Display: Block 
Inline 显示 为 内 联 元 素 
None 默认 值 ,不 浮动 

Float 方 框 | Left 靠 窗口 左 侧 浮动 Float: Right 
Right 靠 窗口 右 侧 浮动 
Static 默认 值 ,无 特殊 定位 

Position: Relative; 
ee Relative 相对 文档 流 位 置 偏 移 显示 Left: 20px; 

Position 定位 Lk 

有 绝对 指定 在 页 面 中 的 位 置 “| 元 素 在 原始 位 置 左 侧 偏 移 
- 20 像素 显示 

Fixed 相对 窗口 边缘 偏 移 显 示 








7.2.2 设计 Div 元 素 








Div 元 素 是 HTML 中 的 块 元 素 , 常 作为 文本 图像 或 其 他 元 素 的 装载 容器 ,实现 区 域 
分 配 。Div 元 素 内 可 以 包含 另 一 个 Div 元 素 ,构成 戏 套 结构 。 


1. Div 元 素 设计 








标签 格式 : 
<Div class ITD -样式 名 商 容 </Div > 
常用 属性 如 表 7-2 所 示 。 
表 7-2 Div 标签 属性 说 明 
属性 DW 名 称 属性 说 明 例子 
Class 类 引用 的 CSS 类 名 Class = " Header" 
Id ID 引用 的 CSS 样式 Id 号 Id =" Logo" 
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Div 元 素 通常 由 CSS 说 明显 示 效 果 和 调整 页 面 位 置 。 一 个 网 页 可 以 包含 多 个 Div 元 
素 ,每 个 Div 元 素 可 以 用 Class 或 Id 属性 引用 具体 的 CSS 样式 。 
2. 浮动 定位 Div 元 素 设计 
在 页 面 中 添加 多 个 < Div > 元 素 时 ,每 个 元 素 ,按照 文档 流 书写 顺序 ,独占 一 行 从 上 到 
下 (纵向 ) 依 次 排列 。 通 过 CSS 设置 Float 的 属性 值 ( 如 Left 或 right) ,可 以 使 < Div > 元 素 
脱离 文档 流 , 当 浏览 器 足够 宽 时 , 相 邻 元 素 可 以 并 排 (横向 ) 显示。 
当 < Div > 元 素 设置 为 浮动 时 ,将 文档 流 原来 位 置 ,向 左 或 向 右 浮 动 , 直 到 碰 到 页 面 边 
缘 或 其 他 浮动 元 素 。 通 过 设 定 浮动 定位 < Div > 元 素 的 宽度 和 高 度 ,可 以 调整 相 邻 元 素 位 
置 。 也 可 使 用 Clear 属性 清除 浮动 元 素 的 位 置 影响 。 
【 例 7.1】 使 用 浮动 定位 在 同行 内 显示 两 个 Div 元 素 。 
代码 如 下 : 
<HIML ><Head > 
<Meta Http -equiv ="Content -Type" Content ="Text/HIML; Charset utf -8" /> 
<Title >Css 布局 实例 </Title > 
<Style Type ="Text /CSS" >.Div left { float: left; } </Style ></Head > 
<Body > Div Class "Div_left" >< 汕 局 靠 左 浮动 YP></Div> 
<Div>@ 沪 局 靠 右 显示 </P></div ></Body ></HIML > 


3. AP Div 元 素 设 计 
Div 元 素 受 相 邻 元 素 限 制 , 显示 位 置 不 固定 ,要 在 页 面 中 指定 位 置 显示 某 些 信息 ,其 


至 重生 显示 ,可 以 用 AP Div 元 素 。 添 加 AP Div 元 素 , 需 要 将 CSS 样式 中 的 Position 属性 
设置 为 Absolute, 并 设置 元 素 的 具体 位 置 大 小 和 芋 放 次 序 等 属性 ,如 表 7-3 所 示 。 


表 7-3 AP Div 标签 的 相关 属性 说 明 


























属性 DW 名 称 属性 说 明 例子 

Position Position 定位 类 型 Position: Absolute 
Left 左 元 素 框 左上 角 相对 于 外 部 容器 边缘 的 左 | Left:200px 

Top 上 边 距 和 上 边 距 Top:100px 

Width 宽 Width: 30% 

元 素 的 宽度 和 高 度 

Height 高 Height: Auto 
Z-index Z 轴 堆 秋 顺序 Z-index: 1 
Visibility 可 见 性 元 素 最 初 是 否 可 见 Visibility: Hidden 











【 例 7.2】 用 绝对 定位 为 图 片 添加 说 明文 字 , 如 图 74 所 示 。 
代码 如 下 : 


<HIML ><Head > 
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<Meta Http -equiv ="'Content -Type 
Content ="Text/HIML; Charset utf -8" /> 
<Title >CSS 布局 实例 </Title > 
<Style Type ="text/css" > 
-Pos abs { Position:absolute; 


Left:60px; Top:100px} 请 更 换 图 像 
</Style ></Head > 
<Body ><Div Class ="Pos_abs" > 请 更 换 图 像 </Div > 图 74 ”框架 型 布局 
<Div > <Img Src "Images/ 头 像 .GIF" Width "200" Height 一 " 
200" /> 
</Div></Body ></HIML > 


4. Div 元 素 设计 向 导 


在 Dreamweaver 的 设计 视图 下 ,光标 定位 到 插入 点 , 单 击 “ 插 入 "菜单 一 “布局 对 象 ” 一 
“Div 标签 "选项 ,在 “插入 Div 标签 "对 话 框 中 ,为 类 或 ID 命名 , 单 击 “ 新 建 CSS 规则 " 按 
钮 。 在“ 新建 CSS 规则 "对 话 框 中 ,选择 类 名 或 ID , 单 击 * 确 定 "按钮 。 在 “CSS 规则 定义 ” 
对 话 框 中 ,可 以 设置 CSS 样式 。 

添加 浮动 定位 DIV 元 素 时 ,可 以 在 “ 方 框 " 类 别 中 设置 Float 和 Clear 等 属性 ,如 图 7-5 
所 示 。 添 加 AP Div 元 素 时 可 以 在 “定位 ”类别 中 设置 Position 等 相关 属性 。AP Div 元 素 
允许 重 和 至 显示 ,Dreamweaver 提供 两 种 方法 选择 元 素 : 一 是 在 设计 视图 中 通过 单 击 选中 ; 
二 是 通过 id 属性 值 在 “AP 元素” 面板 中 选中 。 
















































































div_lef 的 CSS 规则 定义 
分 类 方 杠 
dh) ~ ot :Pett ~ 
Height (NH) ~ mr 明 clesr(c) ~ 
Padding Nargin 
用 回 全 部 相同 (S) 回 全 部 相同 (P) 
Top(F) vm ~ Top(0) ~| 国 时 
Right (FR) : mm ~ Right(G) 
Bottom(B) ottono0 
Left(L) le ~ Left(E) 























图 7-5 ”CSS 规则 定义 窗口 


【 例 7.3】 使 用 CSS 布局 设计 网 页 。 

网 页 通常 包含 标题 . 侧 栏 正文 和 脚注 等 区 域 ,这 些 区 域 可 以 用 不 同样 式 的 Div 元 素 
实现 。 使 用 CSS 布局 设计 如 图 7-6 所 示 的 网 页 结构 。 

(1) 启动 Dreamweaver 新 建 一 个 无 布局 的 网 页 。 

(2) 切换 到 设计 视图 , 单 击 空 白 处 , 单 击 “ 插 入 "菜单 一 “布局 对 象 " 一 “Div 标签 " 选 
项 ,打开 “插入 Div 标签 "对 话 框 。 命 名 类 名 为 Header, 单 击 “ 新 建 CSS 规则 ”按钮 ,在 “新 
建 CSS 规则 ”对 话 框 中 ,选择 器 名 称 为 “. Header”, 单 击 * 确 定 "按钮 ,在 “CSS 规则 定义 ”对 
话 框 中 定义 Div 元 素 样式 。 
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业 : 最 新 职位 : 


名 称 地 址 公司 名 称 岗位 名 称 聘任 要 求 人 数 
食 府 快餐 店 a 长 春 经 济 开发 区 ”工商 前 进 支行 ”会 计 笔试 经 济 学 + 金融 3 
食 府 快餐 店 ”长 春 经 济 开发 区 ”工商 前 进 支行 。” 岗 前 培训 师 笔试 经 济 学 + 金融 2 
腾讯 总 公司 ”北京 市 中 关 村 。 ”腾讯 总 公司 。 理财 师 笔试 : 经 济 法 + 财务 管理 12 
工商 前 进 支行 长 春 市 高 新 区 。 ”腾讯 总 公司 。 经 理 助理 笔试 : 经 济 学 + 人 力 资源 


医大 一 院 长 春 市 朝阳 区 。 ”工商 前 进 支行 ”银行 柜员 计算 机 二 级 ， 笔 试 : 金融 + 会 计 学 5 
首页 | 关于 我 们 | 服务 协议 | 合作 伙伴 | 联系 我 们 
Copyright 


图 7-6 Div 元 素 实例 效果 





(3) 用 同样 的 方式 依次 创建 类 名 为 Container .Left .Right 和 Footer 的 Div 元 素 , 并 为 其 
设 定 样 式 , 其 中 Left 和 Right 类 元 素 散 套 定 义 在 Container 类 内 部 且 Float 属性 值 都 为 Left。 

(4) 在 设计 视图 中 为 每 个 区 分 别 添加 文本 内 容 , 实 现 网 页 布局 。 

(5) 在 “代码 "视图 下 ,优化 后 的 代码 如 下 : 


<HIML > <Head > 
<Meta Http -equiv ="Content -Type" Content ="Text/HIML; Charset utf -8" /> 
<Title >Css 布局 实例 </Title > 
<Style Type ="Text /CSS" > 
.Header {Font -Size:50px;Background -Color: 拥 60; Width:800px; 
Text -align:center; Font -weight:Bold;} 
.Container {Width:800px; Height:160px;Font -size:20px} 
.Left {Float:Left; Width:30%; } /* 设置 为 向 左 浮动 * / 
.Right {Float:Left; Width:70%; Background -Color: $F9;} 
.Footer{Clear:Left; Width:800px; Background: PE; Text Align: Center;} 
/* 清除 左 侧 浮动 元 素 对 位 置 的 影响 * / 
</Style ></Head > 
<Body > 
<Div Class ="Header" > 招聘 信息 </Div > 
<Div Class ="Container" > 
<Div Class ="Left" ><B 状 荐 企业 : YB>… 具体 内 容 省 略 … </Div > 
<Div Class ="Right" ><B 北新 职位 : </B >… 具体 内 容 省 略 … </Div > 
</Div> 
<Div Class =Footer" > 痢 页 | 关于 我 们 : 服务 协议 } 合作 伙伴 ; 联系 我 们 
<Br SCopyRight </Div ></Body > </HIML > 


7.3 ”框架 集 及 框架 设计 


框架 集 是 另 一 种 网 页 布局 方式 ,可 以 在 一 个 浏览 器 窗口 中 显示 多 个 框架 ,每 个 框架 就 
是 一 个 独立 的 HTML 网 页 ,拥有 自己 的 滚动 条 ,操作 时 可 以 互 不 干扰 。 框 架 布 局 常用 于 
导航 内 容 较 多 的 网 页 ,如 将 浏览 器 划分 成 上 下 或 左右 两 个 框架 。 一 般 较 小 的 框架 为 导航 
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区 ; 较 大 的 框架 为 文档 区 , 显示 正文 内 容 。 用 户 通过 导航 区 链接 切换 浏览 文档 区 中 的 内 
容 ,便于 用 户 查找 和 快速 浏览 网 页 。 


7.3.1 设计 框架 集 


框架 集结 构 由 描述 窗口 分 割 方案 的 框架 集 和 呈现 网 页 的 每 个 框架 构成 ,主要 包含 杠 
架 集 < Frameset > 标签 和 框架 < Frame > 标签 。 框 架 集 元 素 的 功能 替换 了 Body 元 素 ,因此 
不 能 将 < Frameset > 标签 和 < Body > 标签 同时 使 用 。 

标签 格式 : 


<Erameset Rows -横向 分 隔 方式 Cols -纵向 分 隔 方式 FrameBorder -有 无 边框 
Border = 边框 宽度 BorderColor = 边框 颜色 值 FrameSpacing = 框架 间距 > 





<Erame Name -框架 名 1 …… > 
<Erame Name -框架 名 n…… > 
[ <rameset … > </Frameset > 
ee ] 
</Frameset > 


框架 集 元 素 内 可 以 添加 新 的 框架 集 , 形 成 嵌 套 结构 。 框 架 集 元 素 的 常用 属性 如 表 74 
所 示 。 
表 74 ”框架 集 标签 的 属性 说 明 




















属性 DW 名 称 属性 说 明 例子 

1 的 权 店 二 册 让 为 而 Rows = 80, +* 

Rows 行 和 条 的 要 站 全 本 方式 ,可 开 为: 丰 】 | 将 页面 正直 分 成 两 个 窗 格 ,上 

9 窗 格 高 80 像素 

1 的 纵 话 本 而 Cols = 100,* 

Cols 列 入 哥 的 纵 内 分 陋 方 式 ,格式 为 : 页 1| 将 页 面 水 平分 成 西 个 窗 格 ,在 
EE ” 窗 格 宽 100 像素 

Frameborder 边框 ie 时 表示 有 边框 ,no 或 0 Frameborder = 1 

Border 边框 宽度 “| 边框 粗细 程度 值 Border = Spx 

Bordercolor 边框 颜色 | 边框 颜色 值 Bordercolor = "#00FF66" 

Framespacing 框架 间距 “| 框架 间距 值 Framespacing =5 














Rows 和 Cols 属性 用 于 定义 框架 集中 的 框架 或 戏 套 框架 集 的 高 度 或 宽度 分 割 方式 , 属 
性 值 字符 串 为 多 个 值 的 列表 ,每 个 值 为 像素 数 px 百分比 % 或 剩余 空间 * 。 

Rows 属性 值 字符 串 中 值 的 个 数 表示 横向 框架 个 数 ,每 个 值 表示 对 应 框架 的 高 度 ; 
Cols 属性 值 字符 串 中 值 的 个 数 表示 纵向 框架 个 数 ,每 个 值 表示 对 应 框架 的 宽度 。 例 如 ， 
Cols = "20% , 50% ，*" ,表示 将 浏览 器 纵向 分 割 成 3 个 框架 ,各 个 框架 的 宽度 分 别 占 浏 
览 器 宽度 的 20% .50% 和 剩余 部 分 。 
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一 个 框架 集 元 素 只 能 定义 一 个 方向 的 分 隔 ,如 果 Rows 和 Cols 都 有 多 个 值 ( 多 行 和 多 
列 ) , 则 仅 是 写 在 前 面 的 属性 有 效 。 例 如 : 

< Frameset Rows ="90 ,80,*" Cols ="100,*" > 横向 划分 3 个 框架 ,纵向 不 再 分 。 

< Frameset Cols ="100,*" Rows ="90,200,*"> 纵向 划分 2 个 框架 ,横向 不 


再 分 。 
7.3.2 设计 框架 


在 框架 集 元 素 中 按 需要 的 顺序 依次 定义 框架 或 嵌 套 的 框架 集 。 此 外 , 当 网 页 中 使 用 
框架 集 后 ,不 能 显示 < Body > 标签 中 定义 的 页 面 ,除非 添加 < Noframes > 标签 , 当 浏 览 器 
不 支持 框架 集 时 不 显示 框架 。 

标签 格式 : 


<Erame Name -框架 名 Src 源 文 件 [Noresize] Scrolling -有 无 滚动 条 
Id -框架 名 标识 名 Title -标题 文字 / > 

















框架 的 常用 属性 如 表 7-5 所 示 。 
表 7-5 ”框架 标签 属性 说 明 

属性 DW 名 称 属性 说 明 例子 
Name | Id 框架 名 称 “| 框架 的 名 称 Name = Framel 
Src 源 文件 资源 名 ,框架 中 内 容 对 应 的 路 径 及 文件 名 | Sre = "Framel. HTML" 
Noresize 调整 大 小 A le 的 大 小 ,加 该 属性 后 不 Noresize 

区 值 为 yes 表示 有 滚动 条 ,no 表示 无 滚动 条 ， 更 吧 

Seroling 。 | 滚动 auto 表示 页 面 尺寸 不 足 时 有 滚动 条 0 
Title 标题 标题 文字 











框架 标签 主要 定义 框架 的 属性 ,Sre 属性 用 于 描述 框架 中 内 容 的 来 源 , 即 显示 在 框架 
内 的 资源 名 。Name 属性 定义 框架 的 名 称 ,在 其 他 框架 中 ,可 以 通过 链接 的 Target 属性 引 
用 该 框架 名 称 , 明 确 被 链接 对 象 的 显示 位 置 。 

例如 ,在 导航 框架 页 中 添加 链接 < A Href = Frame2. HTML Target = Framel > ,浏览 网 
页 时 , 单 击 该 链接 后 ,将 在 Framel 框架 内 显示 文件 Frame2. HTML 网 页 的 内 容 。 


7.3.3 框架 集 及 框架 设计 向 导 
通过 Dreamweaver 可 视 化 向 导 操 作 也 可 以 设计 和 配置 框架 集 及 框架 。 


1. 设计 框架 集 及 框架 
在 “插入 "面板 中 ,从 “布局 ”的 “框架 "下 拉 框 中 选择 一 种 框架 类 型 ,如 “ 左 侧 框架 ”。 
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包 


在 “框架 标签 辅助 功能 属性 对 话 框 中 ,为 每 一 个 框架 设置 名 称 , 单 击 “ 确 定 "按钮 , 即 可 生 
成 框架 集 。 

单 击 “ 文 件 " 菜 单一 "新建" 一 “示例 中 的 页 "一 “框架 页 "选项 ,选择 一 个 预 设 框 架 类 
型 ,也 能 生成 具有 初始 框架 布局 的 框架 集 。 


2. 查看 和 调整 框架 集 及 框架 


在 “框架 "面板 中 , 单 击 某 个 框架 区 域 选 中 框架 ; 单 击 框架 集 的 外 边框 线 选中 框架 集 。 
在 “代码 "视图 中 ,系统 以 已 选中 的 形式 显示 定义 当前 选中 对 象 (框架 或 框架 集 ) 的 代码 ; 
在 “设计 ”视图 中 ,用 虚线 框 显示 当 前 选中 的 框架 或 框架 集 , 拖 动 框架 的 内 边框 线 , 可 以 改 
变相 关 框 架 的 大 小 ; 拖 动 框架 的 外 边框 线 ,能 增加 框架 和 谍 套 的 框架 集 ; 拖 动 框架 集 的 外 
边框 线 ,将 增加 框架 。 

在 “设计 ”和 ”代码 "视图 中 , 单 击 框架 或 框架 集 , 也 能 以 不 同 的 方式 选中 对 象 ,在 “ 属 
性 "面板 中 还 可 以 设置 当前 对 象 的 相关 属性 。 


3. 设计 框架 的 网 页 


要 设计 框架 集 还 需要 设计 每 个 框架 对 应 的 网 页 文件 。 在 “设计 "视图 下 ,选中 框架 ， 
在 框架 区 域内 或 在 “代码 "视图 下 ,可 以 直接 编辑 对 应 的 网 页 内 容 , 也 可 以 单 击 “ 文 件 " 菜 
单一 “在 框架 中 打开 "选项 ,将 已 存在 的 网 页 文件 选 为 当前 框架 的 网 页 。 

在 “框架 "面板 中 选中 框架 后 ,在 “属性 ”面板 中 设置 * 源 文件 ” ,也 能 选择 当前 框架 的 
网 页 文件 。 

4. 保存 框架 集 


框架 集 是 独立 的 HTML 文件 ,只 保存 框架 的 结构 , 即 , 仅 描述 框架 及 框架 集 嵌 套 形式 
等 信息 ;框架 集中 的 每 个 框架 也 需要 对 应 一 个 网 页 文件 ,因此 ,一 个 框架 集 至 少 对 应 框架 
数 加 1 个 文件 。 只 有 保存 了 所 有 文件 ,才能 正确 显示 网 页 。 当 调整 完 框架 集 和 框架 后 , 单 
击 “ 文 件 " 菜 单 一 “框架 集 男 存 为 "选项 ,可 以 单独 保存 框架 集 文 件 ,也 可 以 单 击 “ 文 件 " 菜 
单 一 “保存 全 部 "选项 ,将 所 有 文件 分 别 保存 到 各 自 的 文件 中 。 


7.3.4 ”框架 集 柑 套 


要 使 网 页 纵横 同时 划分 多 个 框架 ,需要 用 框架 集 骨 人 套 的 形式 实现 。 所 谓 框架 集 租 套 
就 是 在 应 该 定义 框架 的 位 置 再 定义 子 框架 集 ,在 子 框架 集中 再 定义 框架 。 

【 例 7.4】 设计 一 个 上 方 为 网 页 标题 ,下方 左 侧 放 置 导航 目录 ,下 方 右 侧 为 正文 的 杠 
架 型 布局 网 页 ,浏览 网 页 效果 如 图 7-7 所 示 。 

(1) 单 击 “文件 "菜单 一 新建"。 在 “ 先 建文 档 " 对 话 框 中 , 单 击 “示例 中 的 页 ”一 
“框架 页 "一 “上 方 固定 , 左 侧 内 套 " 选 项 ,再 单 击 “ 创 建 " 按钮。 在 “框架 标签 辅助 功能 
属性 ”对话 框 中 ,选择 LeftFrame 框架 ,输入 标题 为 导航 页 ” ;选择 TopFrame 框架 ,输入 
标题 为 “标题 页 ” ;选择 MainFrame 框架 ,输入 标题 为 “正文 页 ”。 最 后 单 击 “确定 ” 按 
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招聘 职位 bs 




















稀 职 类 行业 从 。 。 销售 代表 今天 广州 还 桓 贸 上 公司 
换 史 ns 图 0 
-- “* 百度 推广 销售 代表 (高 .- 今天 成 都 百 都 科技 有 限 公司 | 
秆 货 * [四 川 /成 都 市 ] 应 局 毕业 生 / 大 专 6000-8000 政信 / 非 亡 而 M1 其 佑 | 才 售 1500 人 以 上 里 
， 销 售 代表 今天 广州 市 米 航 商 务 服务 有 限 公司 . 
和 * [广东 /广州 市 -] 1 年 /中 专 4100-7800 诊 几 大 务 / 需 育 下 蜀 | 民 部 / 弄 从 | 21 一 50 人 
. 销售 代 去 今天 江苏 无 乙 生 坟 茶 业 科技 有 限 公司 
财务 /会 计 / 审 主 ” [江苏 /无 锡 市 …] 1 年 /大 专 3000-30000 下 他 / 闫 万 刊 册 移 磊 他 | 居 部 乔 从 | 了 4 一 100 人 
。 业 务 员 今天 西安 石 开 实业 有 限 公司 
会 让 出纳。 宣 计 * [陕西 /西安 市 .] 5 年 /大 专 面议 政信 天 六 乔 厅 欧 丰硕 | 尾部 弄 从 121 一 50 人 
* 和 急 聘 汽车 美容 销售 业务 .. 今天 广州 市 海珠 区 新 怠速 汽车 配件 饰品 上 店 
力 资源 /行政 / 安 本 * [广东 /广州 市 ] ! 年 /中 专 5000-8000 鞠 流 /所 葵 | 尼 学 /者 从 121 一 50 人 
< mw > 入 全 寻 十 











图 7-7 框架 型 布局 网 页 效果 


钮 ,创建 框架 集 。 

(2) 在 设计 视图 中 , 单 击 “ 标 题 页 "框架 内 部 ,添加 网 页 标题 和 横幅 背景 图 片 ; 单 击 
“导航 页 "框架 内 部 ,添加 分 类 的 导航 链接 ; 单 击 * 正 文 页 "框架 内 部 ,添加 当前 的 文章 主题 
内 容 , 并 在 “页 面 属性 "中 修改 背景 颜色 为 米黄 色 。 

(3) 在 设计 视图 中 , 拖 动 框架 间 的 边框 线 ,调整 框架 的 尺寸 ,如 “标题 页 "高 度 为 92 
像素 “导航 页 "宽度 为 247 像素 。 在 “框架 "面板 中 选中 “导航 页 "框架 ,修改 “属性 "面板 
中 的 “滚动 选项 为 "是 ” ,为 页 面 添加 滚动 条 。 

(4) 单 击 “ 文 件 " 菜 单一 “保存 全 部 "选项 ,分 别 保存 框 架 集 文件 为 MainFrameset. 
HTML ,标题 页 文件 为 TopFrame. HTML, 导航 页 文件 为 LeftFrame. HTML, 正文 页 文件 为 
MainFrame. HTML, 

(5) 在 框架 集 的 “代码 ”视图 下 ,优化 后 的 代码 如 下 : 


<HIML ><Head > 
<Meta Http -equiv ="Content -Type" Content ="Text/HIML; Charset autf -8" /> 
<Title 3 无 标题 文档 </Title ></Head > 
<Frameset Rows 2"92, * " Cols 2" * " Frameborder 2"No" Border 2"0" Framespacing 2"0" > 
<Frame Src ="TopFrame .HIML" Name ="TopFrame" Scrolling ="No" 
Noresize Title 一 标题 页 "”/ > 
<ETrameset Rows 二 * " Cols = 一 '247,* " Framespacing ="0" 
Frameborder ="No" Border ="0" > 
<Frame Src ="LeftFrame.HIML" Name ="LeftFrame" Scrolling ="Yes" 
Noresize Title 下 导航 页 " /> 
<Erame Src 2"MainFrame .HIML" Name 一 MainFrame" Title "正文 页 " /> 
</Frameset > <NoFrames > 
<Body >x 称 的 浏览 器 无 法 处 理 框架 ! </Body > 
</Noframes > </Frameset ></HIML > 


从 上 述 代码 中 可 以 看 出 ,外 层 框 架 集中 有 上 下 两 个 框架 ( 窗 格 ) ,下 框架 是 一 个 子 框 
架 集 ,由 左右 两 个 框架 ( 窗 格 ) 构 成 。 
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7.4 表格 设计 


表格 的 基本 作用 是 在 网 页 中 显示 结构 化 数据 。 由 于 文本 和 图 像 插 和 页面 后 ,会 随 济 
览 器 尺寸 变化 而 改变 位 置 , 将 其 放 入 表格 内 可 保持 其 位 置 ,所 以 表格 也 可 用 于 页 面 布 局 。 


7.4.1 表格 的 基本 结构 


表格 由 一 行 或 多 行 组 成 ,每 行 又 由 一 个 或 多 个 单元 格 组 成 列 , 行 、 列 及 单元 格 有 效 地 
描述 了 二 维 信息 的 组 织 方式 。 

为 了 更 好 地 实现 布局 效果 ,一 个 完整 的 表格 结构 还 包括 标题 .边框 ,填充 和 单元 格 边 
距 等 概念 ,如 图 7-8 所 示 , 这 些 表格 的 结构 概念 说 明 如 下 : 


标题 (Caption) 


| 


表格 标题 





列 标题 单元 格 (TH) 
表格 边框 (Border) 





单元 格 填充 (Cellpadding) 
数据 单元 格 (TD) 

















单元 格 间距 (Cellspacing) 
图 7-8 表格 的 结构 


(1) 标题 (Caption) : 表格 上 方 居中 显示 的 文字 内 容 , 可 以 省 略 。 

(2) 列 标题 单元 格 (TH) : 表格 中 第 1 行 ,也 称 表 格 列 标题 ,默认 以 粗 体 居中 显示 。 
(3) 表格 边框 (Border) : 整个 表格 的 外 部 边框 线 或 单元 格 的 边框 线 。 

(4) 单元 格 填充 (Cellpadding) : 在 单元 格 内 部 ,内 容 与 边框 之 间 的 空 区 域 。 

(5) 数据 单元 格 (TD ) : 装载 数据 ,包括 文字 、 图 像 和 链接 等 内 容 , 可 以 多 行 。 

(6) 单元 格 间 距 ( Cellspacing) : 两 个 相 邻 单元 格 边框 之 间 的 空白 区 域 。 


7.4.2 设计 表格 


表格 是 较 复 杂 的 结构 ,可 以 添加 到 页 面 任意 位 置 ,需要 多 个 标签 配合 才能 创建 表格 。 
1. 设计 表格 结构 

标签 格式 : 

<Table Cellpaqding -单元 格 边 距 Cellspacing -单元 格 间距 
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Align -表格 对 齐 方式 Wigth 表格 宽度 Border 表格 边框 线 宽度 > 
<Caption > 表格 标题 </Caption > 
<Ir ><Ih 光标 题 1 </Th ><Th 测 标 题 2 </Th >…… <Th 闻 标 题 n<Th><Tr> 
<Tr><Td 立 元 格 1 </Td ><Td 涪 元 格 2 </Td >……… <Td 阅 元 格 n</Td><Tr> 
wooees </Table > 


(1) Table 标签 通过 属性 描述 表格 整体 结构 ,常用 属性 如 表 7-6 所 示 。 
表 7-6 Table 标签 属性 说 明 


























属性 DW 名 称 属性 说 明 例子 
Cellpadding 填充 单元 格 填充 Cellpadding = 10 
Cellspacing 单元 格 间 距 | 单元 格 间 距 值 Cellspacing = 10 
Width 表格 宽度 ”| 表格 的 宽度 ,可 为 像素 或 百分比 Width = 200px 
Border 边框 粗细 表格 边框 线 宽 度 Border = Spx 


(2) < Caption > … </Caption > 标签 定义 表格 的 标题 ， 默认 居中 显示 在 表 体 上 方 。 
(3) < 让 >…</T > 标签 用 于 定义 表格 的 一 行 , < Tr > 元 素 的 个 数 与 表 行 数 一 致 ， 
在 元 素 内 部 通过 < Th > 或 <Td > 标签 定义 当前 行 包含 的 列 单元 格 。 有 时 为 了 简化 代码 ， 
相 邻 的 两 个 < Tr > 开始 标签 中 可 以 省 略 结束 标签 </Tr > 。 
(4) <Th >…</Th > 标签 用 于 定义 表 头 单元 格 ,单元 格 内 容 默认 以 粗 体 居 中 显示 。 
(5) <Td >…</Td > 标签 用 于 定义 普通 单元 格 。 相 邻 的 两 个 < Th > 或 <Td > 开始 
标签 中 可 以 省 略 结束 标签 。 
【 例 7.5】 生成 图 7-8 中 所 示 的 表格 。 
HTML 代码 如 下 : 
<Table Border "2" Cellpadding ="3" Cellspacing 3"1" > 
<Caption > 表格 标题 </Caption > 
<Tr ><Th > 表 头 单元 格 <Ih > 表 头 单元 格 <rh > 无 头 单元 格 
<Tr ><Td 阅 元 格 <Td 阅 元 格 <ra 举 元 格 
<ITr ><Td 阅 元 格 <Td 阅 元 格 <Td 阅 元 格 <Td><Tr> 
</Table > 


2. 表 行 属性 
表 行 属性 用 于 描述 该 行 中 各 个 单元 格 的 属性 。 
标签 格式 : 


<Tr Align -水 平 对 齐 方 式 Valign -垂直 对 齐 方式 Bgcolor 背景 颜色 …… > 
单元 格 描述 </Tr > 


常见 属性 及 其 含义 见 表 7-7 的 前 3 行 。 


(ed 


表 7-7 表 行 及 单元 格 属性 


























属性 DW 名 称 属性 说 明 例子 
Align 水 平 单元 格 内 容 水 平 对 齐 方式 : Left Center 或 Right Align = Left 
单元 格 内 容 和 让 对 齐 方式 ; Top( 顶端 ) Middle( 居 | _ 
lia 重 直 中 ) .Bottom( 底部) 或 BaseLine( 基 线 ) oben = Bob 
Bgcolor 背景 颜色 单元 格 内 背景 颜色 Bgcolor = #00CC99 
Rowspan | Rowspan 合并 单元 格 行 数 Rowspan = 3 
Colspan Colspan 合并 单元 格 列 数 Colspan = 2 
3. 单元 格 属性 
标签 格式 : 
<Td Align -水平 对 齐 方式 Valign = 垂直 对 齐 方式 Bgcolor = 背景 颜色 
Rowspan = 合并 行 数 Colspan = 合并 列 数 Width -宽度 Height =- 高度 …… > 


单元 格 内 容 </Td > 
每 个 单元 格 可 以 设置 不 同 的 属性 值 , 如 表 7-7 所 示 。 如 果 不 设置 属性 值 , 则 按 系统 默 
认 值 。 


通讯 录 


| 电话 E-mail 
|13804318893 olilii@sina.com 


[13988699912 ldh@ilu.edu.cn 
|15888990157 [wim@sina.com 








图 7-9 表格 网 页 示例 一 一 通讯 录 





单元 格 能 够 作为 容器 ,可 以 在 内 部 添加 文本 内 容 和 其 他 标签 ,如 图 像 链接 和 视频 等 。 
为 了 适应 不 同 应 用 场合 ,可 以 在 单元 格 标签 内 增加 “Rowspan = 行 数 "或 “Colspan = 列 数 ”， 
使 单元 格 横 跨 几 行 或 几 列 ,实现 多 个 单元 格 合并 。 
【 例 7.6】 输出 如 图 7-9 的 通讯 录 网 页 。 
通讯 录 网 页 的 代码 如 下 : 
<HIML ><Head > Meta Http -equiv ="Content -Type" Content ="Text/HIML; Charset =utf -8"/ 
短 
<Title 洋 系 人 </Title ></Head> 
<Body> 
<Table Width A00 Border 之 Cellpadding 3 Cellspacing A > 
<Caption > 通讯 录 </Caption > 
<Tr ><Th Width 了 6 :姓名 <rmh Width 导 11 半 话 <Ih Width 忆 69 Fmail 
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<Tr ><Td 部 丽 丽 <td 习 3804318893 
<Td>< 必 Href mailto:l1iuli@ sina.com>1ilili@ sina.com </A> 
<Tr ><Td 济 | 德 厚 </td > <td 5313988699912 
<ITd > A Href mailto:1dh@ jlu.edu.cn >dh@ jlu.edu.cn /A> 
<rr><rda 症 丽 敏 <rda 导 5888990157 
<Td> 必 Href :mailto:wlme sina.com wlm@ sina.com</R></Td></Tr > 
</Table ></Body > </HIML > 


7.4.3 表格 设计 向 导 


1. 插入 表格 


在 Dreamweaver 的 设计 视图 中 定位 插入 点 , 单 击 “ 插 入 "面板 的 “常用 "类 别 “ 表 格 " 按 
钮 ,在 “表格 ”对话 框 中 设置 表格 整体 参数 ,包括 
行 、 列 数 . 表 格 宽度 .边框 粗细 , 边 距 .填充 .标题 
和 表格 列 ( 行 ) 标题 版 式 等 内 容 ,如 图 7-10 所 
示 , 最 后 单 击 “ 确 定 "按钮 ,实现 表格 设计 。 


2. 添加 单元 格 内 容 


在 设计 视图 中 , 单 击 目标 单元 格 设置 插入 
点 ,可 以 在 单元 格 内 添加 内 容 。 单 元 格 内 容 包 
括 文本 和 图 像 等 ,也 可 以 再 添加 表格 形成 表格 
般 套 ,组 成 更 复杂 的 表格 结构 。 

从 其 他 文件 导入 表格 数据 的 方法 : 单 击 
“插入 "菜单 一 “表格 对 象 " 一 “ 导 和 人 表格 式 数 
据 " 选 项 ,选择 文件 名 等 , 单 击 “ 确 定 " 按 钮 。 文 图 7-10 “表格 "对 话 框 
件 类 型 可 为 Excel 和 Txt 等 。 


3. 设置 表格 属性 


在 “属性 ”面板 中 可 以 进一步 如 下 调整 表格 : 

(1) 表格 设置 : 单 击 表格 边框 选中 表格 ,在 “属性 ”面板 可 对 表格 整体 进行 设置 。 

(2) 单元 格 设置 : 鼠标 单 击 , 拖 动 或 按 住 Cul 键 再 单 击 单元 格 等 可 以 选 定单 元 格 ,再 
单 击 “ 属 性 "面板 右 下 角 的 箭头 ,显示 “单元 格 " 扩 展 栏 ,实现 单元 格 设置 。 

(3) 表格 行 或 列 设置 : 将 鼠标 移动 到 行 首 或 列 顶 部 ,光标 变 为 箭头 , 单 击 选 中 行 或 
列 ,“ 属 性 "面板 显示 “单元 格 " 扩 展 栏 ,可 以 设置 正 行 ( 列 ) 单 元 格 。 


7.4.4 利用 表格 进行 布局 


表格 布局 曾经 是 页 面 布局 的 常用 方式 ,优点 是 操作 简单 ,功能 强大 ;缺点 是 不 便于 样 
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式 和 内 容 分 开 ,代码 元 余 大 ,逐渐 被 CSS 布局 所 取代 。 现 在 表格 布局 经 常 出 现在 单个 Div 
区 域内 部 , 当 元 素数 量 较 多 时 ,例如 有 多 幅 图 片 ,通过 表格 实现 精确 排版 。 

Dreamweaver 专门 为 表格 布局 提供 了 扩展 模式 ,在 该 模式 下 ,表格 的 边框 和 填充 都 加 
宽 显 示 ,方便 用 鼠标 调整 ,显示 与 标准 模式 一 致 

【 例 7.7】 插入 展示 图 片 的 Div 区 域 ,用 表格 为 
其 布局 ,如 图 7-11 所 示 。 

(1) 在 “设计 "视图 下 ,选择 “插入 "面板 的 “布局 ” | 各 扫 执 多 二 知 
分 类 , 单 击 “ 扩 展 " 一 “插入 Div 标签 "一 “确定 ”按钮 ， 
添加 Div 元 素 。 AdsGo | Tenceni 半 | " 守 几 是 

(2) 删除 Div 元 素 内 自动 生成 的 文本 , 单 击 “ 插 ce 
和 人 "面板 的 “表格 "按钮 ,在 “表格 " 对话 框 中 设置 “ 行 半 团 估 定 $ 
数 " 为 4,“ 列 数 " 为 3,“ 表 格 宽度 "为 700,“ 边 框 粗细 ” ei on 国信 让 委 
为 1,“ 单 元 格 边 距 " 为 5, 单 击 “ 确 定 ” 按 钮 后 ,在 Div 元 
素 内 添加 表格 。 

(3) 选中 表格 第 1 行 的 3 个 单元 格 , 单 击 “ 属 性 "面板 中 的 “合并 所 选单 元 格 "按钮 ， 
合并 3 个 单元 格 。 修 改 “ 背 景 颜色 ”为 浅 绿色 ,添加 单元 格 内 容 如 “明星 企业 ”。 

(4) 选中 表格 后 3 行 的 所 有 单元 格 ,在 “属性 "面板 中 ,设置 “水 平 "为 “居中 对 齐 ”， 
“垂直 ”列表 为 “居中 ”。 

(5) 单 击 “ 文 件 " 菜 单一 “保存 "选项 ,为 网 页 文件 命名 ( 如 Table. html) ,选择 保存 位 
置 (如 rczp) 。 

(6) 光标 分 别 置 于 后 3 行 的 每 个 单元 格 , 单 击 “ 插 入 "菜单 一 "图像" 选项 ,选择 对 应 
文件 名 ,如 image/Logol. png ,image/Logo2. png … image/ Logo9. png。 

(7) 在 “代码 ”视图 下 ,生成 的 局 部 HTML 代码 如 下 : 


<Body ><Div > 
<Table Width ="700" Border ="1" Cellpadding ="5" Cellspacing ="0" > 
<Tr > <Ih Height ="76" Colspan 2"3" Bgcolor =" 抽 6FF66" Scope "Col" ><H1 > 明星 企业 </HL 
> 
<Tr Align ="Center" Valign ="Middle" > 
<Td > <Img Src ~"Image/Logol .png" ><Td > <Img Src ="image/Logo2 .png" > 
<Td > <Img Src ="Iimage/Logo3 .png" > 
<Ir Align ="Center" Valign ="Middle" > 
<Td > <Img Src =" Image/Logo4 .png" > <Td > <Img Src =" Image/Logo5 .png" > 
<Td > <Img Src =" Image/Logo6 .png" > 
<Ir Align ="Center" Valign ="Middle" > 
<Td > <Img Src =" Image/Logo7 .png" > <Td > <Img Src =" image/Logo8 .png" > 
<Td > <Img Src =" Image/Logo9 .png" ></Td ></Tr ></Table ></Div ></Body > 





























图 7-11 用 表格 布局 的 图 片 展示 区 
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7.5 表单 及 其 控件 设计 


表单 是 网 站 服务 器 和 客户 端 浏览 器 进行 数据 交互 的 桥梁 ,常用 于 收集 用 户 信息 。 当 
用 户 在 表单 控件 中 输入 信息 并 提交 后 ,由 服务 器 端的 脚本 程序 接收 和 处 理 , 再 将 处 理 结果 
生成 新 的 页 面 返回 给 用 户 浏览 器 。 


7.5.1 表单 概述 
浏览 网 页 时 ,经 常会 遇 到 账号 注册 ,账户 登录 和 搜索 信息 等 要 求 , 需 要 填写 文本 内 容 ， 


选择 选项 , 单 击 菜单 选项 或 按钮 等 操作 ,如 图 7-12 所 示 。 在 设计 网 页 时 ,可 以 通过 表单 
(窗口 ) 及 其 控件 实现 这 些 交互 性 的 操作 。 



























































文本 框 

身份 证 号 : 
姓名 : [匿名 | 

文本 区 域 一 + 一 一 一 一 入 
个 人 简历 : 当 
最 后 学 历 : 无 〇 专科 〇 本 科 〇 研究 生 口 博士 生 

音 选 按钮 组 | 请 语种 一 加 无 口 英语 口 日 语 口 俄语 口 其 他 
复 选 框 组 
列表 文艺 人 | 

特长 : 性交 当 学 位 : [学 土 v 
要 附加 的 佐证 资料 文件 浏览 … 


























命令 按钮 一 -十 是 | 傅 

















文件 按钮 
图 7-12 ”注册 账户 页 面 中 使 用 的 表单 


表单 是 网 页 中 的 一 种 特殊 容器 标签 ,由 表单 标签 定义 容器 边界 ,在 容器 内 添加 文本 
框 \ 列 表 , 按 钮 等 表单 控件 以 获取 用 户 信 息 。 表 单 提交 后 ,表单 数据 可 以 被 PHP、ASP JSP 
或 CGI 等 多 种 服务 器 脚本 程序 处 理 。 


7.5.2 设计 表单 


<Eorm Action -接收 数据 的 程序 文件 名 Target -接收 数据 程序 的 打开 位 置 
Enctype -编码 类 型 Method 发送 表单 数据 的 方法 名 Name = 表单 名 >… <Eorm> 


常用 属性 如 表 7-8 所 示 。 


表 7-8 表单 主要 属性 说 明 
属性 DW 名 称 属性 说 明 例子 


人 有 六 机 数据 程序 的 打开 位 和 ,居住 信 间 re lek 








收 表单 数据 的 程 上 表示 程 | Action ="YPRYZC. PHP" 
Pn 操作 或 动作 接收 表单 数据 的 程序 文件 名 ,# 表 示 程 























序 代码 在 当前 文件 中 Action ="#" 
Enctype 编码 类 型 表单 数据 发 送 前 如 何 编码 Enctype = Text/Plain 
Method 方法 表单 向 服务 器 发 送 数据 的 方法 名 Method = " Post" 
Name 名 称 表单 名 称 Name = fml 


1. 编码 类 型 


编码 类 型 Enctype 属性 用 于 定义 表单 的 数据 编码 方式 ,属性 值 有 如 下 三 种 : 

(1) Application/X-www-Form-urlencoded: 为 默认 值 ,指定 表单 数据 发 送 到 服务 器 之 
前 对 所 有 字符 编码 , 即 空格 转换 为 " +" ,特殊 符号 转换 为 ASCII 码 。 

(2) Text/Plain: 指定 表单 数据 以 纯 文本 方式 发 送 ,不 对 特殊 字符 编码 。 

(3) Multipart/Form-data; 指定 表单 数据 以 二 进 制 形式 发 送 , 不 对 字符 编码 , 当 在 表单 
中 传递 文件 时 ,必须 使 用 该 值 。 


2. 方法 


Method 属性 用 于 定义 提交 表单 的 方法 ,属性 值 为 Get 和 Post。 

(1) Get 方法 : 发 送 表单 控件 数据 时 ,通常 附加 在 资源 名 后 作为 参数 发 送 给 Web 服 
务 器 ,通过 *?" 与 资源 名 连接 ,参数 之 间 用 “&" 相连 。 例 如 ,LocalHost/Login. PHP ? Name 
=ywy & Password = ywy211 ,表示 向 Login. PHP 传递 两 个 参数 ,Name( 用 户 名 ) 为 ywy， 
Password( 密码) 为 ywy211。 在 PHP 程序 中 用 数组 $ _GET 接收 数据 。 

(2) Post 方法 : 表单 控件 数据 发 送 给 Web 服务 器 ,在 PHP 程序 中 用 数组 $_POST 接 
收 数据 。 

Get 方法 和 Post 方法 的 主要 区 别 在 于 : Get 是 默认 的 表单 控件 数据 传递 方法 ,一 般 通 
过 资源 名 传输 数据 ,执行 效率 高 ,但 安全 性 较 差 ,也 受 资源 名 的 长 度 限制 ,常用 于 从 服务 器 
获取 和 测试 数据 ,如 通过 表单 控件 实现 查询 或 搜索 。Post 方法 通常 将 表单 控件 数据 放 在 
PHP 程序 中 进行 处 理 , 也 可 以 加 密 , 安 全 性 更 高 且 没 有 长 度 限 制 ,常用 于 向 服务 器 提交 数 
据 , 如 通过 表单 修改 用 户 资料 等 。 

【 例 7.8】 设计 如 图 7-12 所 示 的 表单 。 

设计 表单 的 代码 如 下 : 

<HIML ><Head > 

<Meta http -equiv ="Content -Type" Content ="text/html; CharSet utf -8" /> 

<Title 六 聘 人 员 注 册 </Title ></Head > 

<Body > om Action ="YPRYZC .PHP" Method ="Post" Name ="fml" Target =" new" > 
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身份 证 号 : <Input Type ="Text" Name "SFZH" Size 一 18" Maxlength 一 18" /><br> 
姓 名 : <Input Type ="Text" Name 一 XM" Value 一 匿名 "Size 一 5"><br> 


< ><Input Type ="Submit" Name ="ZC" Value 了 一 注册" /> 
<Input Type ="Reset" Name "CZ" Value = 重 置 " /></P> 

</Fom > </Body > </HIML > 

本 例 使 用 的 方法 是 Post, 单 击 浏览 器 表单 的 “注册 "按钮 时 ,执行 程序 YPRYZC. PHP 
接收 表单 控件 上 的 数据 。 

3. 添加 表单 的 操作 

在 Dreamweaver 中 ,光标 置 于 要 添加 表单 的 位 置 ,进行 下 列 操作 添加 表单 : 

(1) 从 “插入 "面板 中 选择 “表单 "类 型 , 单 击 “ 表 单 " 按 钮 。 

(2) 单 击 “ 插 入 "菜单 一 “表单 "一 “表单 "选项 。 

这 两 种 操作 都 将 打开 “标签 编辑 器 一 Form”" 对 话 框 ,可 以 设置 操作 ,方法 目标 和 名 称 
等 信息 ,最 后 单 击 “ 确 定 "按钮 可 以 添加 表单 。 在 “属性 "面板 中 还 可 以 进一步 设置 表单 的 
相关 属性 值 。 


7.5.3 设计 表单 控件 


表单 只 是 其 控件 的 框架 ,规划 表单 区 域 ,用 户 实 际 操作 的 是 表单 控件 ,主要 用 Input 
和 Select 等 标签 实现 ,通过 Type 属性 值 标识 控件 的 类 型 。 表 单 控件 如 表 7-9 所 示 。 
表 7-9 Input 标签 类 型 

















Type 属性 值 控件 类 型 Type 属性 值 控件 类 型 
Text 文本 .文本 字段 或 文本 域 Button 普通 按钮 
Password 密码 框 Reset 重演 按钮 
Checkbox 复 选 框 Submit 提交 按钮 
Radio 单 选 按 钮 Image 图 像 域 提交 按钮 
File 文件 上 传 按钮 














与 添加 表单 类 似 ,在 “插入 "面板 中 ,选择 “表单 "类别 , 单 击 对 应 的 控件 类 型 按钮 ,或 
者 , 单 击 “ 插 入 "菜单 一 “表单 "一 对 应 的 控件 类 型 选项 ,在 相关 对 话 框 中 设计 控件 ,如 图 7-13 
所 示 。 可 以 选择 或 输入 控件 的 详细 分 类 ,名称 和 值 等 , 最 后 单 击 “ 确 定 ” 按 钮 ,向 表单 中 添 
加 控件 。 在 “属性 "面板 中 也 可 以 设置 表单 控件 的 相关 属性 值 。 

要 处 理 表单 控件 上 的 输入 或 选择 数据 , 还 要 进一步 设计 PHP 程序 (脚本 ) 。 


1. 文本 ( Text) 
文本 也 称 文本 字段 或 文本 域 ,俗称 文本 框 ,用 于 输入 一 行 数据 ,属性 如 表 7-10 所 示 。 
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标签 编辑 器 一 input 





党 规 
样式 表 / 辅 助 功能 
语言 


日 事件 
onBlur 
onChange 
一 onClick 
onDblClick 
‘onoeus 











omllouseDown 

omllouseUp 

ollouseDver 
omllousellove 
omllouseDut 
onkKeyPress 
onKeyDown 
onkKeyUp 
onSelect 














图 7-13 表单 控件 编辑 器 
标签 格式 : 


<Input Type 了 ext Name = 文本 名 Size -宽度 Maxlength -最 多 字符 数 
Value 数据 …… y > 


表 7-10 文本 框 和 密码 框 主要 属性 说 明 














属性 DW 名 称 属性 说 明 例子 
Name 文本 域 文本 字段 文本 名 称 Name = Textfield 
Size 字符 宽度 输入 域 的 显示 宽度 Size =20 
Maxlength ”| 最 多 字符 数 可 输入 字符 串 的 最 大 长 度 Maxlength =200 
Value 初 值 设置 初 值 和 存储 输入 的 数据 Value = UserName 








2. 密码 框 ( Password) 
密码 框 简称 密码 ,用 于 输入 一 行 数据 ( 密码 ) ,用 户 输入 数据 时 ,系统 显示 星 号 ”* "或 


标签 格式 : 
<Input Type -Password Name -密码 框 名 Size -宽度 
Maxlength -最 多 字符 数 Value -密码 ……/ > 
相关 属性 及 其 含义 与 文本 框 相同 ,如 表 7-10 所 示 。 
【 例 7.9】 设计 用 户 登录 表单 。 
部 分 代码 如 下 : 
<Form Name ~"'Fomml " Method ="Post" Action =" 和 > 
用 户 名 : <Input Type ="Text" Name 一 Name" /> 
密码 : <Input Type ="Password" Name 一 Pw" /> 
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</Eorm> 


3. 文本 区 域 ( 编辑 框 ) 





文本 区 域 控件 是 文本 框 控件 的 扩展 ,用 于 输入 并 显示 多 行文 本 ,通过 TextArea 标签 实 
现 ,常见 于 输入 个 人 简历 和 内 容 提要 等 信息 。 

标签 格式 : 

<TextArea Name -文本 区 域名 Cols - 列 数 Rows 4 了 数 Value 数据 ……/> 

主要 属性 的 含义 如 下 : 

(1) Cols 属性 : 规定 文本 区 域 框 中 每 行 能 显示 的 字符 个 数 ( 列 数 ) , 当 输 入 数据 超过 





此 列 数 时 ,超出 的 数据 自动 到 下 一 行 显示 。 


(2) Row 属性 : 规定 文本 框 的 高 度 , 即 ,同时 能 显示 的 数据 行 数 。 当 数据 超出 此 行 数 


时 ,将 隐藏 多 余 的 数据 行 ,可 以 通过 光标 控制 键 或 垂直 滚动 条 滚动 显示 数据 行 。 


(3) Value 属性 : 用 于 设置 文本 区 域 的 初始 显示 数据 ( 初 值 ) 和 存储 新 输入 的 数据 。 
【 例 7.10】 设计 图 7-12 中 的 个 人 简历 控件 。 
设计 代码 如 下 : 


个 人 简历 : <TextArea Name "JL" Cols ="50" Rows ="3" /> 
4. 单 选 按 钮 ( Radio) 
多 个 单 选 按钮 (也 简称 单 选 ) 组 成 一 个 单 选 按钮 组 , 单 选 按钮 组 是 表单 中 的 选择 性 控 


件 ,每 个 单 选 按钮 以 圆 形 “ © "或 “DO "呈现 在 表单 上 。 一 个 表单 中 可 以 放置 多 个 单 选 按 
钮 , 几 个 单 选 按钮 可 以 设置 相同 的 Name 属性 值 构成 一 组 ,用 不 同 的 Value 值 区 分 彼此 。 
在 浏览 器 的 表单 中 ,每 个 单 选 按钮 组 中 只 能 选中 一 项 。 主 要 属性 如 表 7-11 所 示 。 
标签 格式 : 
<Input Type =Radio Name < 单 选 按钮 组 名 Value = 选项 值 [Checked] …… 及 


表 7-11 单 选 按钮 的 主要 属性 说 明 




















属性 DW 名 称 属性 说 明 例子 
Name 名 称 单 选 按钮 组 名 称 Name = XL 
Value 选 定 值 设置 选中 对 象 时 所 取 的 值 Value =1 
Checked 初始 为 选中 状态 每 组 中 只 能 选中 一 项 Checked = " Checked" 或 Checked 


【 例 7.11】 设计 图 7-12 中 选取 学 历 的 单 选 按钮 组 。 


部 分 代码 如 下 : 
最 后 学 历 : <Input Type ="Radio" Name "XL" Value 习 Checked / 湛 
<Input Type ="Radio" Name 2"XL" Value 之 /法 科 
<Input Type ~"Radio" Name "XL" Value 汪 / 亲 科 
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<Input Type =Radio" Name 一"XL" Value 忆 / > 研究 生 
<Input Type ~"Radio" Name "XL" Value 起 / : 靖 士 生 


5. 复 选 框 (CheckBox) 


多 个 复 选 框 组 成 一 个 复 选 框 组 , 复 选 框 组 也 是 表单 中 的 选择 性 控件 ,每 个 复 选 框 以 矩 
形 “ 口 "或 “V" 呈 现在 表单 上 。 一 个 表单 中 可 以 有 多 个 复 选 框 组 ,相同 名 称 (Name 属性 
值 ) 的 多 个 复 选 框 为 一 组 ,各 个 复 选 框 具有 不 同 的 Value 值 ,以 便 区 分 选中 哪 项 。 在 浏览 
器 的 表单 中 ,每 个 复 选 框 组 中 可 以 选中 多 项 。 

标签 格式 : 














<Input Type =CheckBox Name = 复 选 框 组 名 [] Value = 选项 值 [Checked] …… 1 > 
从 浏览 器 表单 的 每 个 复 选 框 组 中 ,可 以 同时 选中 多 项 ,为 了 保存 多 个 被 选中 项 的 值 
(Value) , 复 选 框 组 名 后 加 中 括号 ”[ ] ”表示 数组 。 主 要 属性 如 表 7-12 所 示 。 
表 7-12 复 选 框 的 主要 属性 说 明 











属性 DW 名 称 属性 说 明 例子 
Name 名 称 复 选 框 组 名 称 Name=WY[] 
Value 选 定 值 设置 选中 对 象 时 所 取 的 值 “| Value =1 
Checked “| 初始 为 选中 状态 | ”每 组 中 可 以 选中 多 项 Checked =" Checked" 或 Checked 











【 例 7.12】 设计 图 7-12 中 选取 外 语 语种 的 复 选 框 组 。 
部 分 代码 如 下 : 

外 语 语种 : 

<Input Type ="Checkbox" Name 23"WY[]" Value -0 Checked /六 
<Input Type ="Checkbox" Name ="WY[]" Value 1/ 漠 语 

<Input Type ="Checkbox" Name ="WY[]" Value 之 / 间 语 
<Input Type ="Checkbox" Name ="wY[]"” Value 扎 / 懂 语 
<Input Type ="Checkbox" Name =2"WY[]" Value 也 / 闯 他 


6. 命令 按钮 


命令 按钮 是 用 户 与 网 页 交互 的 通用 触发 器 控件 ,可 细 划 分 为 按钮 ( Button ) . 重 置 
(Reset) 和 提交 (Submit) 三 种 类 型 。 主 要 属性 如 表 7-13 所 示 。 

标签 格式 : 

<Input Type =Button |Reset |Submit Name -按钮 名 Value = 显示 的 文字 ……- 人 


单 击 浏览 器 表单 上 的 不 同类 型 的 按钮 ,系统 响应 的 行为 有 所 不 同 , 各 类 命令 按钮 的 具 
体 行为 如 下 : 
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表 7-13 命令 按钮 的 主要 属性 说 明 
属性 DW 名 称 属性 说 明 例子 
Name 名 称 按钮 名 称 Name = Cmd 
Value 值 按钮 上 显示 的 文本 内 容 “| Value = Submit 











(1) Reset( 重 置 ) : 清除 表单 控件 上 的 输入 或 选择 信息 ,还原 到 各 控件 的 初始 值 。 
(2) Submit( 提交) : 将 各 个 控件 的 值 存 储 到 超 全 局 数组 $_POST 或 $_GET 中 ,同时 
触发 (执行 ) Action 属性 指定 的 PHP 网 页 程序 文件 。 当 Action 属性 值 为 “#" 时 ,执行 当前 


网 页 文件 中 的 PHP 程序 代码 。 


(3) Button( 按 钮 ) : 通常 与 客户 端 脚本 配合 使 用 ,实现 网 页 的 特殊 效果 。 设 计 按 钮 
时 ,可 以 在 标签 内 添加 OnClick 事件 ,通过 “OnClick = 函数 名 ”的 形式 ,指定 单 击 按钮 后 执 


行 哪 个 脚本 函数 。 
【 例 7.13]】 


设计 图 7-12 中 的 注册 和 重 置 按钮 。 


部 分 代码 如 下 : 


<Input Type ="Submit" Name ="ZC" 
<Input Type ="Reset" Name ="CZ" 


7. 图 像 域 
图 像 域 简称 图 像 ,实际 是 一 种 图 像 按钮 。 有 时 为 了 达到 比较 好 的 视觉 效果 ,可 以 在 表 


Value 一 注册 "”/ > 
Value =" 重 置 " /> 


单 中 设计 图 像 按 钮 ,其 行为 与 提交 (Submit) 按钮 相同 。 图 像 按 钮 还 可 以 配合 客户 端 脚本 
实现 表单 重 蜀 等 更 加 复杂 的 功能 ,如 验证 码 按钮 等 。 主 要 属性 如 表 7-14 所 示 。 


标签 格式 : 


<Input Type -Tmage Name -按钮 名 Src -图 像 文件 路 径 
Align -对齐 方式 Alt -替代 文本 …… /> 


表 7-14 图 像 域 提交 按钮 的 主要 属性 说 明 























属性 DW 名 称 属性 说 明 例子 
Name 名 称 按钮 名 称 Name = Imgcmd 
Sre 源 文件 资源 名 ,图 像 文 件 及 所 在 路 径 Src = " Image/1. gif" 
Mn 对 齐 图 像 对 齐 方式 Align = Left 
Alt 替换 图 像 无 法 显示 时 的 替代 文本 Alt = "图像 无 法 显示 " 

【 例 7.14】 设计 图 7-12 中 的 图 像 按 钮 。 

部 分 代码 如 下 : 

<Input Type 2"Image" Name ="TXAN" Src ="Image/Ht.GIF" /> 

8. 选择 列表 


选择 列表 以 选项 域 的 方式 提供 一 组 选项 ,用 < Select > 标签 定义 选项 域 , < Option > 标 
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签 定义 选项 ,俗称 列表 框 。 
标签 格式 : 
<Select Name -列表 框 名 [] Size = 显示 列表 行 数 [Multiple] > 
<Option Value = 选项 值 1 [Selected] > 选项 的 显示 文本 </Option > 


<Option Value = 选项 值 n [Selected] > 选项 的 显示 文本 </Option > 
</Select > 
可 以 从 浏览 器 表单 的 每 个 列表 框 中 同时 选中 多 项 (加 Multiple 选项 ) ,列表 框 名 后 要 
加 中 括号 对 “[ ] ” ,表示 用 该 数组 存储 被 选中 的 多 个 值 (Value) 。 列 表 框 的 主要 属性 如 
表 7-15 所 示 。 
表 7-15 ”列表 与 菜单 控件 的 属性 说 明 


























属性 DW 名 称 属性 说 明 例子 
Name 选择 列表 框 名 称 Name= TC[] 
Size 高 度 列表 框 中 同时 显示 行 数 Size =3 
Multiple | 允许 多 选 ”| 允许 选中 多 项 ,省 略 此 属性 ,只 能 选中 一 项 | Multiple = Multiple 或 Multiple 
Value 值 设置 选中 对 象 时 所 取 的 值 Value =1 
Selected | 初始 选中 项 | 初始 时 处 于 选中 状态 Selected = Selected 或 Selected 
9. 选择 菜单 
选择 菜单 也 俗称 下 拉 列 表 框 ,由 下 拉 按 钮 和 下 拉 列 表 组 成 。 
标签 格式 : 


<Select Name = 下 拉 列 表 框 名 > 
<Option Value = 选项 值 1 [Selected] > 选项 的 显示 文本 </Option > 


<Option Value = 选项 值 n [Selected] > 选项 的 显示 文本 </Option > 
</Select > 
下 拉 列 表 框 通常 仅 显 示 一 个 选项 (一 行 ) , 仅 当 单 击 下 拉 按 钮 时 才 显示 列表 ;从 下 拉 
列表 框 中 只 能 选中 一 项 。 下 拉 列 表 框 与 列表 框 对 比 , 除 没有 Size 和 Multiple 属性 外 ,其 他 
属性 及 含义 相同 。 
【 例 7.15】 设计 图 7-12 中 选取 多 个 特长 的 列表 框 (TC[ ] ) 和 选取 一 个 学 位 (XW) 
的 下 拉 列 表 框 。 
部 分 代码 如 下 : 
特长 : <Select Name "TC[]" Size 3 Multiple > 
<Option Value 习 体育 Selected > 体育 woOption ><Option Value 之 文艺 汶 艺 option> 
<Option Value 己 社交 淋 交 </Option ><Option Value 双 其 他 Selected 湛 他 </option > 


基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


</Select > 

学 位 : <select Name "XW" > 
<Option Value 习 3 无 </Option ><Option Value 之 Selected 学 十 <option > 
<Option Value 当 并 学 十 </Option ><Option Value 也 颈 士 /Option > 
<Option Value 起 靖 士 </option ></Select > 


10. 文件 域 ( 文件 上 传 按钮 ) 

文件 域 是 一 种 特殊 的 表单 控件 ,由 文本 框 和 * 浏 览 "按钮 组 成 。 用 户 在 浏览 器 中 单 击 
“浏览 "按钮 ,将 打开 文件 选择 对 话 框 ,允许 选择 或 输入 文件 名 ,表单 提交 后 将 文件 上 传 到 
Web 服务 器 。 要 使 文件 域 能 传输 文件 ,表单 的 传输 方式 必须 为 Post ,数据 编码 类 型 为 
Multipart/Form-data ,并 确保 服务 器 允许 上 传 文件 。 主 要 属性 如 表 7-16 所 示 。 

标签 格式 : 

<Input Type 于 ile Name = 文件 域名 Size 输入 域 宽度 

Maxlength = 最 大 字符 数 Accept = 文件 类 型 …… /> 
表 7-16 文件 域 的 主要 属性 说 明 























属性 DW 名 称 属性 说 明 例子 
Name 文本 域名 称 “| 文件 域名 称 Name = "FJ" 
Size 字符 宽度 输入 域 的 显示 宽度 Size =20 
Maxlength 最 多 字符 数 输入 字符 的 最 大 长 度 Maxlength = 100 
& 可 接收 的 文件 类 型 ,多 种 类 型 之 间 用 逗 | Accept = " Image/Gif ， 
Accept 文件 类 型 号 分 隔 ep 


【 例 7.16】 设计 图 7-12 中 的 资料 提交 按钮 。 
部 分 代码 如 下 : 


要 附加 的 佐证 资料 文件 : 
<Input Type ="File" Name ~"FJ" Size 之 0 Maxlength 之 00 Accept ="Image/Gif"/ > 


7.6 ”Spry 构件 设计 


Spry 框架 是 Dreamweaver 中 内 置 的 客户 端 脚本 库 , 可 以 用 来 构建 效果 更 丰富 ,用 户 体 
验 更 好 的 Web 页 面 。Spry 框架 通过 JavaScript 和 CSS 实现 多 种 功能 丰富 的 Spry 构件 
( Widget) ,只 需要 简单 的 设置 和 少量 的 代码 修改 ,就 能 向 网 页 中 添加 如 : 网 站 菜单 、 折 对 
面板 和 验证 表单 等 多 种 具有 交互 性 的 动态 内 容 。 


@) 


7.6.1 Spry 构件 的 概念 


Spry 构件 是 特殊 的 页 面 元 素 , 通 过 与 用 户 交互 ,为 访问 者 提供 更 好 的 用 户 体验 。Spry 
构件 作为 非常 流行 的 脚本 技术 ,由 以 下 几 个 部 分 组 成 

(1) 构件 结构 : 描述 构件 如 何 组 成 的 HTML 代码 。 

(2) 构件 行为 : 描述 构件 如 何 响应 用 户 交互 事件 的 JavaScript 代码 。 

(3) 构件 样式 : 描述 构件 外 观 的 CSS 代码 。 

Spry 构件 可 以 使 用 “插入 ”面板 的 “Spry" 分 类 ,快速 地 插入 各 种 构件 , 青 通过 “属性 ” 
面板 加 以 调整 。 每 个 插入 的 构件 都 与 唯一 的 CSS 和 JavaScript 文件 相关 联 ,保存 在 站 点 中 
的 SpryAssets 目录 。 对 于 具有 HTML .CSS 和 JavaScript 知识 的 设计 人 员 ,通过 直接 修改 
CSS 样式 代码 ,可 以 设计 更 专业 的 Spry 构件 。 

“属性 "面板 也 提供 “ 自 定 义 此 Widget" 选 项 ,允许 用 户 从 互联 网 上 下 载 该 构件 更 多 的 
个 性 化 版 本 。 


7.6.2 Spry 菜单 栏 构件 


Spry 菜单 栏 构 件 是 一 组 导航 菜单 按钮 ,有 垂直 和 水 平 两 种 菜单 栏 构件 。 当 鼠标 滑 过 
按钮 时 ,将 显示 对 应 子 菜单 ,图 7-14 是 展开 了 三 级 菜单 的 水 平 布局 的 Spry 菜单 栏 。 用 
Spry 菜单 栏 可 以 在 页 面 中 设计 大 量 导 航 链接 。 


-EE i -tan 职场 资讯 


按 行业 搜索 ， 
东北 地 区 


按 职能 搜索 ”华北 地 区 
华东 地 区 





图 7-14 ”Spry 菜单 栏 样式 


在 Dreamweaver 的 “插入 "面板 中 选择 Spry 分 类 , 单 击 “Spry 菜单 栏 " 按 钮 ,在 弹出 对 
话 框 中 选择 布局 方向 ,就 可 创建 Spry 菜单 栏 。 选 择 整 个 Spry 菜单 栏 后 ,可 在 “属性 "窗口 
中 查看 菜单 栏 的 设置 。Spry 菜单 栏 包含 三 个 级 别 的 菜单 ,如 图 7-15 所 示 。 


菜单 栏 一 级 菜单 ”二 级 菜单 菜单 项 设置 















































图 7-15 ”Spry 菜单 栏 参 数 设 置 
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按照 表 7-17 可 以 分 别 为 每 个 菜单 级 别 设置 相应 的 菜单 项 内 容 。 
表 7-17 Spry 菜单 栏 的 常用 属性 说 明 
属性 值 描述 
菜单 条 设置 当前 Spry 菜单 栏 的 识别 ID 








回 嘉 件 中 找 不 到 关系 ID 
pa 的 图 惊 部 


在 当前 菜单 级 别 中 ,添加 或 删除 菜单 项 























编辑 按钮 
园 文件 中 找 不 到 关系 
人 在 当前 菜单 级 别 中 ,将 菜单 项 上 移 或 下 移 
一 个 位 置 
文本 定义 当前 选择 的 菜单 项 显示 文本 
链接 定义 当前 选择 的 菜单 项 链接 目标 
禁用 样式 禁用 当前 菜单 栏 所 使 用 的 CSS 样式 


7.6.3 Spry 折 释 式 构件 


Spry 折 私 式 构件 是 一 个 可 折 释 面板 组 ,用 于 将 大 量 内 容 存储 在 一 个 紧凑 的 固定 空 
间 。 面 板 组 中 每 个 面板 的 内 容 可 通过 单 击 选项 卡 条 来 隐藏 或 显示 。 折 县 构件 可 以 包含 任 
意 数量 的 单独 面板 ,但 每 次 只 能 展开 一 个 内 容 面板 。 单 击 不 同 的 选项 卡 时 , 原 面板 就 会 收 
缩 而 新 面板 就 会 展开 。 图 7-16 呈现 了 过 渡 动 画 。 


销售 管理 ， 


哮 条 经 问 t \ 析 局 会 计 经 
销售 经 理 销售 主管 客户 经 理 客户 主管 区 域 销售 经 理 务 经 理 财务 顾问 财务 助理 财务 分 析 员 会 计 经 理 











区 域 销售 专员 /助理 








图 7-16 Spry 折 番 式 构 件 切换 示例 


在 Dreamweaver 的 “插入 "面板 中 选择 Spry 分 类 , 单 击 “Spry 折 芋 式 " 按 钮 , 即 可 创建 
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Spry 折 闭 式 构件 。 
选择 折 盖 式 构件 后 ,通过 “属性 "窗口 的 “面板 "列表 ,可 以 编辑 构件 的 选项 卡 个 数 和 
位 置 。 切 换 到 和 欲 修改 版 面 可 以 修改 选项 卡 标题 和 内 容 。 


7.6.4 Spry 选项 卡 式 面 板 构件 


和 折 县 式 构件 类 似 ,Spry 选项 卡 式 面板 构件 也 是 将 大 量 内 容 存储 在 一 个 紧凑 空间 的 
面板 组 ,通过 单 击 选 项 卡 条 来 隐藏 或 显示 板块 内 容 。 不 同 的 是 ,选项 卡 式 构件 的 所 有 选项 
卡 条 是 横向 排列 ,上 且 面板 高 度 随 面板 内 容 而 改变 ,如 图 7-17 所 示 。 











销售 代表 客户 代表 销售 工程 师 区 域 销售 专员 /助理 











图 7-17 Spry 选项 卡 式 构件 切换 示例 


在 Dreamweaver 的 “插入 "面板 中 选择 “Spry” 分 类 , 单 击 “Spry 选项 卡 式 面板 "按钮 ， 
即 可 创建 选项 卡 式 构件 。 编 辑 选 项 卡 式 构件 的 内 容 和 标题 与 折 笃 式 构件 相同 。 


7.6.5 Spry 工具 提示 构件 


Spry 工具 提示 构件 的 功能 是 : 当 用 户 鼠 标 悬 停 在 网 页 特定 元 素 上 时 ,由 其 显示 设 定 
的 提示 信息 ; 当 鼠 标 移 走 后 ,提示 信息 可 以 立刻 消失 ,也 可 以 再 停留 一 段 时 间 ,方便 用 户 与 
提示 内 容 交互 。 工 具 提 示 构 件 能 为 各 种 页 面 对 象 提供 说 明 信 息 ,较为 常用 。 

Spry 工具 提示 构件 包含 以 下 三 个 元 素 : 

(1) 工具 提示 容器 : 用 户 触 发 提示 功能 时 用 于 显示 消息 内 容 。 

(2) 工具 提示 触发 器 : 用 于 触发 提示 功能 的 页 面 特定 对 象 。 

(3) 工具 提示 脚本 : 用 于 描述 提示 信息 的 显示 方式 的 JavaScript 脚本 。 

在 Dreamweaver 的 “插入 ”面板 中 选择 “ Spry” 分 类 , 单 击 “ Spry 工具 提示 ”按钮 ,就 可 
以 创建 工具 提示 控件 。 

在 设计 视图 中 可 以 看 到 ,生成 的 工具 提示 控件 包含 一 个 工具 提示 容器 和 触发 器 元 素 。 


中 的 提示 文本 ,最 后 在 “属性 "面板 中 设置 相关 参数 ,如 表 7-18 所 示 。 
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表 7-18 ”Spry 工具 提示 控件 的 常用 属性 说 明 






































属性 值 描述 
Spry 工具 提示 设置 当前 Spry 工具 提示 控件 的 识别 ID 
触发 器 设置 触发 Spry 工具 提示 控件 的 页 面 对 象 人 D 
水 平 偏 移 量 “| 工具 提示 触发 后 ,设置 工具 提示 容器 和 鼠标 之 间 的 水 平 距离 
垂直 偏 移 量 | 工具 提示 触发 后 ,设置 工具 提示 容器 和 鼠标 之 间 的 垂直 距离 
. 显示 延迟 。 | 工具 提示 触发 后 ,设置 工具 提示 容器 由 隐藏 状态 到 显示 的 间隔 时 间 
委 沿 加 二 征 到。 | 工具 提示 结束 触发 设置 上 提示 容 种 市 显 示 状 态 到 隐 下 的 癌 隔 时间 
“| 跟随 鼠标 。 | 选中 该 项 后 ,工具 提示 触发 后 ,提示 信息 一 直 跟随 鼠标 
全 | 称 刘 交大 “| 和 中 页, 车 届 标 内服 发 天 秘 开 . 风 隐 茂 霸 上 提示 格 作 
无 工具 提示 触发 后 ,不 使 用 特殊 效果 
效果 迹 窒 工具 提示 触发 时 ,为 提示 容器 添加 逐渐 显示 的 效果 
渐 隐 工具 提示 结束 触发 时 ,为 提示 容器 添加 逐渐 隐藏 的 效果 





7.6.6 ”Spry 表单 


Spry 表单 是 附加 了 JavaScript 脚本 的 表单 , 当 有 用 户 交 互 发 生 时 ,能 够 在 表单 提交 前 ， 


自动 检查 表单 元 素数 据 ,做 出 相应 处 理 。 例 如 ,在 要 求 输入 电子 邮件 的 文本 域 中 没有 输入 
“@ "符号 和 句点 ,就 会 返回 用 户 输入 无 效 的 状态 。 


1. 表单 控件 的 常见 状态 
Spry 表单 的 功能 是 由 多 个 Spry 表单 验证 控件 实现 的 。Spry 表单 验证 控件 的 主要 作 


用 是 检查 控件 内 容 是 否 符 合 要 求 , 针 对 不 同情 况 , 表 单 控件 会 显示 以 下 几 种 常见 状态 : 


(1) 初始 状态 : 在 浏览 器 中 加 载 页面 或 用 户 重 置 表单 时 控件 的 状态 。 
(2) 焦点 状态 : 当 表单 控件 获得 用 户 焦点 时 控件 的 状态 。 

(3) 有 效 状态 : 当 用 户 正确 输入 内 容 且 表单 可 以 提交 时 控件 的 状态 。 
(4) 无 效 状态 : 当 用 户 所 输入 内 容 格 式 无 效 时 控件 的 状态 。 

(5) 必需 状态 : 也 称 必 填 状态 ,验证 控件 没有 输入 时 控件 的 状态 。 
(6) 错误 提示 状态 : 当 用 户 所 输入 内 容 有 误 时 ,显示 错误 原因 。 


2. 表单 验证 时 间 


验证 发 生 的 时 间 也 有 三 种 不 同 的 选择 : 

(1) 模糊 onBlur: 当 表 单 控件 失去 用 户 焦 点 时 验证 。 
(2) 更 改 onChange: 当 用 户 更 改 表 单 控件 内 容 时 验证 。 
(3) 提交 onSubmit: 当 用 户 尝试 提交 表单 时 验证 。 
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在 Dreamweaver 中 ,创建 Spry 表单 验证 控件 ,可 以 通过 在 “插入 "面板 的 “Spry” 类 型 
里 ,选择 Spry 表单 验证 控件 名 对 应 的 按钮 实现 。 并 通过 * 属 性 ”面板 设置 具体 的 验证 内 
容 验证 发 生 时 间 ,初始 的 控件 状态 等 参数 。 


3. 表单 验证 的 作用 


(1) Spry 验证 文本 域 : 对 于 一 个 单行 文本 框 控件 来 说 ,具体 的 验证 内 容 可 通过 * 属 
性 "面板 中 的 “类 型 "选项 进行 调整 ,主要 包括 : 文本 格式 .文本 长 度 范围 数值 范围 .是 否 
必 填 等 信息 。 验 证 结果 通过 相应 的 控件 状态 显示 ,可 以 在 “提示 ”选项 中 输入 对 输入 数据 
的 提示 。 

(2) Spry 验证 文本 区 域 : 对 于 一 个 多 行文 本 框 控 件 来 说 ,主要 对 文本 长 度 范围 和 是 
否 必 填 进行 验证 。 也 可 以 为 控件 添加 提示 信息 和 字符 计数 器 。 

(3) Spry 验证 复 选 框 和 Spry 单 选 按钮 组 : 主要 验证 选中 的 选项 个 数 。 可 强制 要 求 至 
少 选 择 一 个 ,或 者 为 复 选 按钮 指定 选中 选项 的 数量 范围 。 

(4) Spry 验证 密码 和 Spry 验证 确认 : Spry 验证 密码 是 密码 类 型 的 文本 域 ,可 用 于 强 
制 执行 指定 的 密码 规则 ,例如 ,密码 中 包含 字母 或 数字 的 数量 ,是 否 有 大 写字 母 等 ,并 为 用 
户 显 示 相 应 的 错误 消息 。Spry 验证 确认 也 是 一 个 密码 类 型 文本 域 , 需 要 为 其 指定 一 个 类 
似 域 作为 匹配 确认 , 当 用 户 与 该 域 的 值 不 匹配 时 , 则 显示 为 无 效 状 态 。 


7.7 模板 设计 与 引用 


一 个 网 站 由 大 量 网 页 组 成 ,为 了 使 这 些 网 页 风格 统一 ,通常 将 网 页 中 和 布局 相关 的 页 
面 元 素 ,如 网 站 Logo ,标题 .导航 栏 .页 脚 等 设计 为 相同 内 容 , 只 改变 网 页 中 的 正文 部 分 ， 
为 了 避免 重复 劳动 ,网 页 设计 前 可 以 先 使 用 Dreamweaver 制作 模板 ,再 基于 模板 实现 布局 
相同 网 页 的 快速 创建 。 

此 外 , 当 网 站 信息 、 风 格 和 布局 等 内 容 发 生变 化 时 ,如 果 所 有 网 页 都 需要 修改 将 十 分 
麻烦 。 使 用 模板 生成 的 网 页 ,可 以 通过 在 Dreamweaver 中 修改 模板 ,使 多 个 网 页 同时 更 
新 , 极 大 地 减轻 网 站 后 期 的 维护 工作 。 


1. 创建 模板 


模板 是 一 种 特殊 的 文档 ,用 于 设计 网 站 中 页 面 布局 相对 固定 的 网 页 。Dreamweaver 专 
门 使 用 DWT 格式 ,将 模板 文件 保存 在 网 站 根 目录 的 Templates 文件 夹 。 创 建 模 板 有 两 种 
方法 : 建立 新 的 空白 模板 和 将 已 有 网 页 男 存 为 模板 。 

(1) 创建 空白 模板 : 单 击 “ 文 件 " 菜 单一 “新 建 " 选 项 ,打开 “新 建文 档 "对 话 框 。 在 
“ 空 模板 ”选项 卡 中 选择 “HTML 模板 ”选项 ,并 指定 一 种 页 面 布局 , 单 击 “ 创 建 "按钮 即 可 
创建 一 个 具有 选中 布局 的 空 模板 。 

(2) 将 现 有 网 页 保存 为 模板 : 要 想 将 现 有 的 网 页 保存 为 模板 ,首先 要 打开 已 有 的 网 
页 文档 。 单 击 “ 文 件 " 菜 单一 “另存 为 模板 "选项 ,选择 保存 路 径 并 设置 模板 名 称 ,将 已 有 
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网 页 保存 为 模板 文档 。 
2. 编辑 模板 


为 了 确保 页 面 风格 统一 ,模板 将 页 面 中 不 变 的 部 分 锁定 ,其 他 变化 的 部 分 ,如 正文 等 
内 容 ,定义 为 可 编辑 区 。 实 际 上 Dreamweaver 为 模板 指定 了 四 种 区 域 : 可 编辑 区 域 .重复 
区 域 可 选区 域 和 可 编辑 的 可 选区 域 。 

(1) 定义 可 编辑 区 域 : 新 创建 的 模板 文档 ,默认 所 有 区 域 都 被 锁定 ,而 为 了 设计 不 同 
的 网 页 内 容 ,模板 至 少 应 该 包含 一 个 可 编辑 区 域 。 选 中 目标 位 置 或 目标 对 象 , 单 击 “ 插 
人 "菜单 一 “模板 对 象 " 一 “可 编辑 区 域 " 选 项 ,打开 “新 建 可 编辑 区 域 " 对 话 框 。 为 新 建 区 
域 设置 调用 名 称 , 单 击 “ 确 定 " 按 钮 ,完成 可 编辑 区 域 的 创建 。 可 编辑 区 域 的 代码 前 后 会 
显示 注释 < ! --TemplateBeginEditable-- > 和 < ! --TemplateEndEditable-- > 。 

(2) 定义 重复 区 域 : 是 模板 的 一 部 分 ,通常 和 网 页 元 素 搭 配 , 用 于 在 基于 模板 的 网 页 中 
重复 显示 。 定 义 时 ,选中 网 页 中 的 某 个 元 素 , 单 击 “ 插 入 "菜单 一 “模板 对 象 " 一 “重复 区 域 ” 
选项 即 可 。 代 码 前 后 显示 <! --TemplateBeginRepeat-- > 和 <1 --TemplateEndRepeat-- > 
注释 。 

(3) 定义 可 选区 域 : 使 用 模板 生成 网 页 后 ,可 选区 域 是 模板 中 可 根据 条 件 选 择 被 显 
示 或 被 隐藏 的 部 分 。 定 义 时 ,也 需要 选中 一 个 网 页 元 素 , 单 击 “ 插 入 "菜单 一 “模板 对 象 ” 
一 “可 选区 域 " 选 项 生成 。 可 选区 域 默认 是 无 法 编辑 的 ,选中 后 , 单 击 “ 插 入 "菜单 一 “模板 
对 象 " 一 “可 编辑 区 域 "选项 可 以 变 为 可 编辑 区 ,同时 拥有 两 种 特性 。 


3. 用 模板 设计 网 页 


创建 模板 并 定义 编辑 区 域 后 ,就 可 以 基于 该 模板 设计 布局 相同 内容 不 同 的 网 页 ,并 
保存 成 独立 的 网 页 文件 。 

单 击 “ 文 件 "菜单 一 “新 建 " 选 项 ,打开 “新 建文 档 ” 对 话 框 。 在 “模板 中 的 页 ”选项 卡 
中 单 击 模板 所 在 的 站 点 ,选择 模板 名 称 , 单 击 “ 创 建 " 按 钮 ,创建 一 个 基于 模板 的 文档 。 在 
文档 中 找到 以 蓝 色 标签 和 边框 显示 的 可 编辑 区 域 ,插入 需要 编辑 的 内 容 ,并 保存 为 相应 的 
网 页 文件 格式 即 可 。 

通过 模板 ,网 站 可 以 创建 一 批 布局 和 风格 一 致 的 网 页 。 如 果 将 来 需要 修改 网 页 布局 ， 
可 以 通过 修改 模板 内 容 ,批量 地 更 新 所 有 使 用 该 模板 生成 的 网 页 。 











习 题 


一 、 填 空 题 

1. 网 页 布局 有 多 种 类 型 ,其 中 “ 厂 字形 "布局 将 整个 页 面 分 为 标题 区 、 中 ”中间 内 
容 区 和 ”@@_ 几 个 区 域 ,其 中 _@ 主要 提供 导航 功能 。 

2. HTML 表格 中 可 以 使 用 _@ 和 @ 标签 定义 行内 的 单元 格 , 当 设置 单元 格 宽 
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度 时 ,通常 采用 百分比 和 ”@ 两 种 单位 。 
3. 使 用 框架 技术 的 网 页 ,包含 QD ”和 框架 页 文件 两 种 ,其 中 前 者 主要 由 _@ 和 
_ @_ 两 种 元 素来 实现 。 
4. HTML 中 的 <p > 元 素 和 < Div > 元 素 属于 Q@ 元 素 , 当 显 示 时 内 容 会 从 新 行 开 
始 ,自动 在 前 后 添加 换行 , <a > 元 素 和 < img > 元 素 属 于 _@) 元 素 , 当 显示 时 元 素 内 容 
可 以 出 现在 同一 行 。 
5. 在 一 个 表单 中 ,表单 标签 的 method 属性 有 _ 四 ， @ 两 个 属性 值 ,如 果 要 求 
提交 的 数据 内 容 不 受 长 度 的 限制 ,其 值 必须 是 _@ 。 
6. 要 在 网 页 中 实现 一 个 用 于 输入 密码 的 文本 框 控件 , 且 文 本 框 的 显示 宽度 为 20 个 
字符 ,需要 使 用 HTML 语 名 <_ 四 Type= @@ 加 =20>。 
7. 一 个 Spry 构件 由 _Q _ ,构件 样式 和 构件 行为 三 大 部 分 组 成 ,这 三 部 分 的 编写 代 
码 分 别 是 HTML 代码 ， @_ 代码 和 ”@_ 代 码 。 
8. 对 于 Spry 表单 的 验证 控件 ,验证 发 生 的 时 间 有 三 种 不 同 选 择 , 当 表 单 控 件 失 去 焦 
点 状态 时 验证 ,需要 设置 为 “中 。 当 表单 控件 的 内 容 验 证 成 功 ,可 以 提交 时 ,该 控件 处 
于 _@ 状态。 
9. 在 HTML 中 可 以 使 用 Input 标签 为 表单 添加 命令 按钮 ,通过 Type 属性 定义 按钮 功 
能 ,其 中 属性 值 为 “中 ”时 , 单 击 后 会 提交 表单 数据 , 若 要 修改 按钮 上 显示 的 文字 ,需要 修 
改 _@_ 属性 。 
10. 在 网 页 设计 技术 中 ， 中 “可 以 实现 由 一 个 文件 的 修改 控制 一 大 批 网 页 的 更 新 ， 
Dreamweaver 专门 将 其 存储 为 扩展 名 为 ”@ 的 文件 。 
11. 创建 模板 文件 后 , Dreamweaver CS5 默认 将 其 中 的 所 有 区 域 标记 为 锁定 ,因此 ,在 
应 用 文档 前 ,需要 在 模板 文档 中 创建 _(D_ 区域。 如果 需要 某 网 页 元 素 在 基于 模板 的 网 
页 中 重复 显示 , 则 需要 在 模板 文档 中 创建 _@ 区 域 ,如 果 需 要 某 网 页 元 素 在 特定 条 件 下 
被 显示 或 被 隐藏 , 则 使 用 _@ 区域。 
二 、 单 选 题 
1. 使 用 Dreamweaver 可 以 创建 包含 预 设 布局 的 网 页 ,下 面 关 于 预 设 布局 的 描述 错误 
的 是 ( ) 。 
A. Dreamweaver 可 以 为 PHP 页 面 生成 预 设 布局 
B. Dreamweaver 可 以 生成 “三 "字形 布局 的 页 面 
C. 当 预 设 布 局 的 侧 栏 为 “ 列 液态 "时 ,该 区 域 的 宽度 会 随 浏览 器 尺寸 变化 
D. 当 预 设 布局 的 侧 栏 为 * 列 固定 "时 ,是 以 百分比 定义 列 宽 
2. CSS 布局 是 现在 主流 的 页 面 布局 方式 ,下 面 对 CSS 布局 的 描述 错误 的 是 ( )。 











A. 能 够 使 代码 精简 B. 页 面 内 容 和 样式 相 分 离 
C. 能 提高 页 面 访问 速度 D. 页 面 内 容 和 样式 不 在 同一 文件 


3. 在 Dreamweaver 中 可 以 向 网 页 插入 表格 并 通过 属性 面板 进行 设置 ,下 面 这 些 表格 
操作 中 ,( ) 是 无 法 直接 通过 Dreamweaver 的 属性 面板 实现 的 。 
A. 合并 单元 格 B. 设置 单元 格 背景 颜色 
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C. 设置 表格 背景 颜色 D. 修改 表格 的 行 、 列 数 
4. 框架 集 标签 使 用 Rows 和 Cols 属性 分 割 页 面 , 下 列 选项 中 ( ) 可 以 将 窗口 分 成 
2 列 , 且 右 边区 域 比 左边 宽 。 
A. Cols = "20%, *" B. Cols = " *, 20%" 
C. Rows = "20%, *" D. Rows = " *, 20%" 
5. 创建 人 才 招 聘 网 站 时 ,可 以 在 网 页 中 添加 表单 控件 ,让 应 聘 人 员 自 行 选择 多 个 感 
兴趣 领域 ,此 时 应 该 在 < Input > 标签 中 将 Type 属性 的 值 设 为 ( ja 


A. Checkbox B. text C. Radio D. submit 
6. 要 一 次 选择 表格 的 整个 行 ,在 标签 检查 器 中 选择 ( )。 
A. <Table > B: <Tt> C. <Td > D. <Th > 
7. 网 页 通过 表单 控件 获取 用 户 信 息 ,下 列 标签 中 ( ) 不 是 表单 控件 标签 。 
A. <Form> B. < Input > C. <Select> D. <TextArea> 


8. 下 面 关 于 HTML 中 单 选 按钮 的 叙述 错误 的 是 ( 短 
A. 单 选 按钮 通过 Checked 属性 指定 是 否 选 中 





B. 多 个 单 选 按 钮 通过 Name 属性 值 分 组 
C. 网 页 中 的 单 选 按 钮 只 允许 有 一 个 被 选中 
D. 同 组 的 单 选 按 钮 应 该 有 不 同 的 Value 值 
9.( ) 的 作用 就 是 将 浏览 器 划分 为 若干 个 区 域 ,每 个 区 域 显 示 不 同 的 网 页 。 
A. 框架 B. 表格 C. 层 D. 表单 
10. 以 下 哪 种 Spry 构件 不 用 于 显示 大 量 的 文本 内 容 ( Wa 
A. Spry 菜单 栏 构件 B.Spry 选项 卡 式 面板 构件 
C. Spry 折 释 式 构件 D. Spry 可 折 伙 面板 
11. Dreamweaver CS5 创建 的 模板 文件 默认 保存 在 ( ) 文 件 夹 中 。 
A. Templates B. Image C. website D. web 
三 、 多 选 题 
1. 在 下 列 网 页 设计 技术 中 ,( ) 可 以 用 于 实现 网 页 布局 。 
A. 表格 B. Div + CSS C. 框架 


D. Spry 构件 E. 表单 
2. 在 HTML 中 可 以 使 用 < Input > 标签 定义 表单 输入 控件 ,并 通过 Type 属性 设置 控 
件 类 型 。 其 中 Type 属性 值 为 ( ) 时 ,可 以 实现 按钮 的 功能 。 
A. Submit B. Checkbox C. Radio D. Text 
E. Password F. Reset 
3. 使 用 Dreamweaver 添加 AP Div 元 素 时 ,该 元 素 的 显示 样式 就 已 经 定义 完成 ,自动 
生成 的 CSS 属性 包括 ( 。”)。 





A. Position B. Left C. Width D. Z-Index 
E. Float F. Display 
4. 在 HTML 标准 中 ,页 面 元 素 按照 显示 模式 和 文档 流 顺 序 依次 呈现 到 浏览 器 中 , 通 
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过 设置 ( ， )CSS 属性 ,可 以 使 HTML 元 素 改变 这 种 默认 规则 。 
A. Float B. Clear C. Display D. Position 
E. Width F. Height 
5. 下 面 关于 表单 控件 的 描述 中 正确 的 是 ( )。 
. 每 组 单 选 按钮 只 能 选中 一 个 
. 复 选 框 和 列表 框 都 使 用 Checked 短语 标识 被 选中 控件 
使 用 键盘 输入 的 表单 控件 都 通过 Input 标签 实现 
使 用 密码 框 输入 文本 时 看 不 到 输入 内 容 
选择 列表 中 Option 元 素 的 个 数 等 同 于 选项 的 个 数 
复 选 框 通过 Value 属性 实现 分 组 
6. 下 面 关于 HTML 表格 的 描述 中 错误 的 是 ( )。 
. 表格 中 <Tr > 元 素 的 个 数 等 同 于 表格 的 行 数 
. 表格 使 用 Cellpadding 属性 定义 单元 格 之 间 的 距离 
. 当 表 格 的 Border 属性 值 为 0 时 ,浏览 器 中 不 显示 边框 
. 单元 格 可 以 使 用 Rowspan 属性 占 满 一 行 
. 当 表 格 宽度 为 像素 值 时 ,表格 不 会 随 浏 览 器 尺寸 改变 
En 下 面 选 项 中 ， 对 于 表单 标签 的 描述 错误 的 是 ( ) 。 
A. Action 属性 值 为 “#" 表 示 由 当前 页 面 处 理 表单 数据 。 
B. 当 表 单数 据 包括 图 片 时 ,应 该 将 Enctype 属性 设置 为 Text/Plain 
C. 当 Method 属性 值 为 Post 时 ,表单 数据 通过 资源 名 参数 传递 
D. 表单 提交 后 ,接收 文件 只 能 通过 $ _POST 变量 获取 表单 数据 
E. 表单 通过 Target 属性 指定 数据 接收 文件 
8. 在 创建 网 站 模板 时 ,下 面 关 于 可 编辑 区 的 说 法 错误 的 有 ( ) 。 
A 
B 
C 
D 





be 


罗 站 吕 Om 


DNm> 


只 有 定义 了 可 编辑 区 才能 将 它 应 用 到 网 页 上 
. 在 编辑 模板 时 ,可 编辑 区 是 可 以 编辑 的 ,锁定 区 是 不 可 以 编辑 的 
. 一 般 将 共同 特征 的 标题 和 标签 设置 为 可 编辑 区 
. 基于 模板 的 网 页 通过 可 编辑 区 才能 修改 
E. 以 上 说 法 都 错 
9. 下 面 选项 中 ,可 以 通过 Spry 控件 实现 的 是 ( js 
A. 交互 式 菜单 B. 数据 搜寻 C. 表单 验证 
D. 网 页 特效 E. 框架 设置 F. 透明 度 设置 
10. 下 述 概念 解释 正确 的 是 ( Ws 
A. URL: 统一 资源 定位 器 ,用 来 访问 其 他 资源 
. HTML: 超级 链接 ,用 来 链接 其 他 资源 
. JP: 网 际 协议 ,或 称 为 Internet 协议 ,可 以 用 来 访问 其 他 主机 
.Spry 控件 : JavaScript 库 , 用 来 设计 功能 更 强大 的 动态 网 站 
. 模板 : 用 来 给 其 他 网 页 做 设计 样 例 的 标准 网 页 
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四 、 程 序 填空 题 


1. 本 题 中 通过 HTML 表单 标签 实现 一 个 简单 登录 界面 。 表 单 采 用 post 提交 方式 , 包 
括 一 个 文本 框 一 个 密码 框 和 提交 按钮 。 请 用 适当 的 内 容 填空 实现 该 页 面 。 


<HTML ><Head > 
<Meta charSet -utf -8"/ > 
<Title > 登录 界面 </Title ></Head > 
<Body > 
<omAction= QD "Post"> 
用 户 名 : <Input Type ="'text" Name ="'userName" Size="15" Maxlength="15" > <Br> 
密码 : <Input Type=" @_ "Name ="'passwords" Size="15"Maxlength="15" > <Br> 
<Input Type = 图 " Value 一 "提交 " /> 
</Form ></Body > </HIML > 


2. 本 题 设计 一 个 模拟 的 在 线 答题 页 面 ,使 用 CSS 布局 将 页 面 分 成 标题 区 Header、 题 
干 区 Questions 和 答题 区 Answer, 其 中 标题 区 位 于 页 面 上 方 , 题 干 区 和 答题 区 并 排 显示 在 
下 方 。 请 用 适当 的 内 容 填空 实现 该 页 面 。 


<HIML ><Head > 
<Meta charSet ="utf -8"/ > 
<Title 次 题 </Title > 
<Style Type ="Text/CSS" > 
_@ Header { text -align: center; font -size: 24px; } 


.Questions { © : -2@ ; width: 70%; height:100px; } 
.Answer { height:100px; } 

</Style ></Head > 

<Body > 


<Div Id ="Header" > 在 线 答题 </Div > 
<Div Class ="Questions" > 网 页 设计 简单 吗 ? </Div > 
<Div Class ="Answer" > 
<Eorm Action ="#P Method ="Get" > 
p> <Input Type 2"Radio" Name 2"answer" Value 导 / 症 </p> 
Pp><Input Type ~'Radio" Name = @ "Value-0 / 辣 <p> 
</Fom > </Div > </Body > /HIML > 


五 、 程 序 运 行 结果 填空 题 


1. 本 题 中 使 用 表格 标签 实现 了 一 个 学 生 选 课 信息 表 , 表 格 的 HTML 代码 如 下 ,请 根 
据 该 代码 ,回答 以 下 问题 。 


<Table Border 3px > 
<Caption ><Font Face 染 书 size 4 ;选课 信息 </Font ></Caption > 
<Tr ><Td > 课程 <ra > 计算 机 <Tq Rowspan 汪 硬 dth 50 痕 片 
<Tr ><Td x 专 业 <Td Web 程序 设计 


(1 


(82 


<Tr ><Td > 年 级 <rd 况 015 
<Tr ><Td 疮 校 名 称 <rd Colspan 之 清 林 大 学 CTQ></Tr ></Table> 


(1) 本 题 中 定义 的 表格 ,是 一 个 _ 中 行 四 列 的 表格 。 
(2) 表格 外 边框 宽度 是 _@ 。 
(3) 行 第 二 列 单元 格 的 内 容 是 四 。 
2. 本 题 中 使 用 框架 布局 实现 了 一 个 简单 的 聊天 室 页 面 ,如 果 框 架 集 所 需 的 网 页 都 已 
设计 完成 ,请 根据 框架 集 页 面 的 HTML 代码 ,回答 以 下 问题 。 
<HIML ><Head > 
<Meta charSet ="utf -8"/> 
<Title 尘 天 室 </Title ></Head > 
<Frameset Rows ="* " Cols ="20%, * " Border ="3" Framespacing ="0" > 
<Erame Src ="User.html" Name =" User " Scrolling =" Yes "/> 
<Erameset Rows ="* " Cols ="* ,30%" Framespacing ="0" Frameborder ="No" > 
<Erame Src ="Message.html" Name =" Message " Scrolling ="Yes" 
Noresize "Noresize" Title 下 导航 页 " / > 
<Erame Src="Send.html" Name =" Send " /> 
</Frameset > 
</Frameset > </HIML > 


在 该 页 面 中 框架 集 由 _ QD _ 个 框架 页 组 成 ,其 中 _@_ 框 架 页 位 于 聊天 室 页 面 的 右 
下 角 , 其 宽度 占 页 面 宽 度 的 百 分 之 _@ ,高 度 占 页 面 高 度 的 百 分 之 _@@ 。 


六 、 程序 设计 题 
1. 请 使 用 Div + CSS 布局 方式 ,用 HTML 代码 实现 一 个 “ 厂 ” 字 型 布局 的 页 面 。 
2. 请 使 用 框架 布局 ,用 HTML 代码 实现 一 个 “三 "字形 布局 的 页 面 。 








“属性 "面板 针对 不 同 对 象 ,有 不 同 的 参数 设置 ,有 无 共同 点 ? 

， 如何 更 改 Spry 框架 中 的 CSS 样式 内 容 ? 

Div 布局 对 象 和 AP Div 布局 对 象 有 什么 区 别 , 各 自 有 什么 优势 ? 
如 何 用 Div + CSS 布局 实现 一 个 三 行 三 列 的 表格 结构 ? 
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PHP 程序 设计 基础 


PHP 语言 是 全 球 最 普及 、 应 用 最 广泛 的 互联 网 程序 设计 语言 之 一 ,具有 简单 .易学 、 
源 代码 开放 、 可 操纵 多 种 数据 库 支持 面向 对 象 编程 .支持 跨 平台 操作 及 完全 免费 等 特点 ， 
至 今 已 被 2000 多 万 个 网 站 采用 。 随 着 PHP 技术 的 成 熟 和 完善 ,已 经 从 一 种 网 络 程序 设 
计 的 语言 发 展 成 为 适合 企业 部 署 互 联网 平台 的 技术 。PHP 基础 知识 主要 包括 下 列 问题 

(1) 如 何 编 辑 和 调试 PHP 程序 ? 

(2) PHP 与 HTML 有 哪些 不 同 ? 

(3) PHP 环境 中 有 哪些 数据 类 型 ? 每 种 数据 类 型 有 哪些 基本 运算 ? 

(4) 如 何 构 建 复杂 的 PHP 表达 式 ? 

(5) 什么 是 正则 运算 ? 在 PHP 程序 设计 中 如 何 应 用 正则 运算 ? 





8.1 PHP 程序 的 编辑 与 运行 


使 用 优秀 PHP 程序 编辑 器 或 开发 工具 能 够 极 大 地 缩短 网 站 的 创建 时 间 ,提高 网 页 程 
序 的 设计 和 开发 效率 ,也 便于 网 站 维护 与 更 新 。 


1. PHP 程序 的 编辑 器 


有 许多 PHP 程序 编辑 器 ,例如 NotePad + + \PHPDesigner Eclipse ,BlueFish 、EditPlus 、 
HTML-Kit .PHPCoder、NetBeans IDE 和 PSPad 等 。 这 些 编辑 器 都 拥有 调试 器 、 增 量 执行 
PHP 脚本 ,查看 每 一 行 的 变量 值 等 功能 。 

编辑 器 各 有 特色 。 例 如 ,Notepad + + ,开源 软件 ,可 以 免费 使 用 ,支持 C、C ++ 、jJava、 
C# XML HTML PHP JavaScript 等 多 种 语言 程序 的 编程 ;内 置 了 支持 多 达 27 种 语法 高 亮 
度 显 示 ; 可 自动 检测 文件 类 型 ,根据 关键 字 显示 节点 ,节点 可 自由 折 对 /打开 ,代码 层次 感 
强 ;可 打开 双 窗 口 ,在 分 窗口 中 又 可 打开 多 个 子 窗口 ,允许 快捷 切换 全 屏 显 示 模 式 ,支持 鼠 
标 滚轮 改变 文档 显示 比例 ;提供 多 种 特色 服务 ,例如 , 邻 行 互 换 位 置 宏 功能 等 。 


2. PHP 程序 的 可 视 化 编辑 和 运行 环境 
Dreamweaver( DW) 是 Web 站 点 及 应 用 程序 的 专业 开发 工具 ,将 可 视 化 布局 工具 、 应 


用 程序 开发 工具 和 代码 编辑 组 合 在 一 起 ,使 得 各 类 设计 人 员 都 能 够 美化 网 站 及 创建 应 用 
程序 。 用 Dreamweaver 开发 PHP 程序 的 最 大 优势 在 于 : 开发 人 员 能 在 同一 软件 环境 中 制 
作 静 态 和 动态 网 页 ,并 且 用 浏览 器 随时 调试 和 运行 网 页 程序 。 

使 用 Dreamweaver 开发 和 调试 PHP 程序 前 ,需要 启动 Apache 及 MySQL 服务 ,配置 站 
点 服务 器 ,并 选中 “测试 "选项 。 

【 例 8.1】 创建 PHP 应 用 程序 ,在 页 面 中 显示 系统 当前 时 间 。 

在 Dreamweaver 中 编辑 及 运行 PHP 程序 的 步骤 如 下 : 

(1) 新 建 PHP 文件 。 单 击 “ 文 件 " 菜 单一 “新 建 " 选 项 ,在 “新 建文 档 " 对 话 框 中 选择 
“文档 类 型 "为 *PHP”, 单 击 “ 创 建 "按钮 。 

(2) 编写 PHP 代码 。 在 “代码 "视图 中 的 < Body > 与 </Body > 之 间 输 入 PHP 程序 
代码 ,如 图 8-1 所 示 。 


Ev) E: \WYSQL_Dw\zampp\htdocs\rezp\PHP_Test. PHP (XHTHL)*# 


《!DOCTYPE html PUBLIC “~-//W3C//DTD XHTML 1.0 Transitional//EN” 国 
“http: //www. w3. org/TR/xhtml1/DTD/xhtmll-transitional. dtd”> 
Chtml xmlns="http://www. w3. org/1999/xhtml”> 
SM Chead> <meta http-equiv="Content-Type” content="”text/html; 
charset=utf-8” /> 
《tit1le>PHP 程 序 示 例 《/title>《/head> 


/ 将 时 区 设置 为 北京 区 
// 按 24 小 时 制 显示 系统 时 间 








TK7 1 秒 Unicode (UTF-8) 


图 8-1 Dreamweaver 的 “代码 "视图 


(3) 保存 PHP 文件 。 单 击 * 文 件 " 菜 单一 “保存 "选项 ,输入 文件 名 ,如 PHP_Test. 
PHP, 单 击 “ 保 存 " 按 钮 。 

(4) 运行 PHP 程序 。 单 击 “ 实 时 视图 "选项 ,在 实时 视图 窗 格 中 查看 浏览 效果 ; 单 击 
“文档 "工具 栏 中 的 “在 浏览 嚣 中 预览 /调试 "选项 ( 栈 ) ,在 选 定 的 浏览 器 中 浏览 PHP 程 
序 的 运行 结果 。 


8.2 PHP 程序 的 语法 


1. PHP 标记 


PHP 标记 能 够 让 Web 服务 器 识别 PHP 代码 的 开始 和 结束 ,两 个 标记 之 间 的 所 有 文 
本 都 会 被 解释 成 为 PHP ,而 标记 之 外 的 任何 文本 都 会 被 认为 是 普通 的 HTML, 这 就 是 PHP 
标记 的 作用 。PHP 标记 风格 有 下 列 4 种 。 

(1) 标准 风格 。 以 “ < ?PHP” 开 始 ,以 “? > "结束 ,中 间 写 入 任意 行程 序 代码 。 
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【 例 8.2】 标准 风格 的 PHP 程序 。 


<?2PHP 
Echo "标准 风格 标记 "; // 页 面 输出 文字 : 标准 风格 标记 
要 
(2) 脚本 风格 。 以 < Script Language =" PHP" > 开始 ,以 </Script > 结束 ,中 间 写 人 
任意 行程 序 代 码 。 在 XHTML 或 者 XML 中 推荐 使 用 这 种 标记 风格 ,其 符合 XML 语言 
规范 。 
【 例 8.3】 脚本 风格 的 PHP 程序 。 
<Script Language ="PHP" > 
Echo "脚本 风格 标记 "; // 页 面 显示 文字 : 脚本 风格 标记 
</Script > 
(3) 简短 风格 。 以 ” <? "开始 ,以 *“? > "结束 ,中 间 写 人 任意 行程 序 代码 。 这 种 标记 
风格 简单 .书写 方便 ,但 要 求 更 改 配 置 文件 PHP. INL, 在 该 文件 中 增加 Short_Open_Tag = 
On 语句。PHP. INI 文件 通常 保存 在 系统 盘 Windows 文件 夹 中 。 
【 例 8.4】 简短 风格 的 PHP 程序 。 


<? 
Echo "简短 风格 标记 "; // 页 面 显示 文字 : 简短 风格 标记 
和 入 
(4) ASP 风格 。 以 “ <% ”开始 ,以 “% > "结束 ,中 间 写 入 任意 行程 序 代码 。 这 种 风 
格 与 ASP 相同 。 如 要 使 用 ASP 风格 ,同样 需要 修改 配置 文件 PHP. INI, 在 其 中 增加 ASP_ 
Tags = On 语句 。 
【 例 8.5】 ASP 风格 的 PHP 程序 。 
<% 
Echo "ASP 风格 的 标记 "7 // 页 面 显示 文字 : ASP 风格 的 标记 
名 > 


2. PHP 的 语法 规则 


(1) 一 个 完整 的 PHP 代码 必须 是 以 "< ?PHP”" 或 *<?" 开 头 ,并 以 “? > "结尾 。 

(2) PHP 语句 必须 以 分 号 * ; "结尾 。 

(3) 在 PHP 中 ,所 有 系统 函数 .用 户 定 义 的 函数 、 类 和 关键 字 ( 例如 If、Else .Echo 等 ) 
都 不 区 分 大 小 写 , 而 变量 名 区 分 大 小 写 。 

(4) 语句 短语、 函数 名 中 的 英文 字母 .专用 符号 ( 如 各 种 运算 符 , 单 引号 、 双 引号 、 圆 
括号 等 ) 一 律 以 半角 方式 输入 。 


3. PHP 注释 
注释 即 代码 的 解释 和 说 明 , 通 常 放 在 代码 的 上 方 或 尾部 ,是 书写 规范 程序 的 重要 部 
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(es 


分 ,用 于 解释 脚本 的 用 途 版权 说 明 ,版 本 号 编写 人 员 编写 时 间 等 。 注 释 不 会 被 作为 程 
序 执行 ,作用 仅 是 供 阅读 代码 时 参考 。 注 释 可 以 使 用 如 下 3 种 风格 。 

(1) C++ 风格 的 单行 注释 。 注 释 内 容 单 独 一 行 或 者 放 在 程序 代码 的 后 面 ,用 两 条 和 斜 
杠 *“// "开始 ,其 后 书写 注释 内 容 ,以 回 车 符 作 为 注释 的 结束 。 

【 例 8.6】 C++ 风格 的 程序 注释 。 


<?2PHP 
Echo "网 上 人 才 招 聘 管理 系统 "; // 本 行 语句 用 于 显示 软件 名 称 
> 
(2) C 风格 的 多 行 注释 。 以 “/* ”开始 ,以 “ * /结束 ,其 间 的 全 部 内 容 均 为 注释 内 
容 。 需 要 注意 的 是 注释 内 容 中 不 能 出 现 “ * /”, 否则 系统 会 判定 注释 到 此 位 置 结 束 而 出 
现 语法 错误 。 
【 例 8.7】 C 风格 的 程序 注释 。 


<?PHP 
/* 本 程序 用 于 显示 两 个 变量 的 求 和 结果 ,其 中 变量 的 值 在 定义 变量 时 直接 给 定 ， 
如 要 实现 其 他 计算 ,只 需要 增加 相应 的 程序 代码 即 可 * / 
息 丑 0; 移 :20; 
Echo " 摆 + 由 二 ， 押 + 各; /* 结果 : 10 420 汪 0* / 
EE 


(3) Shell 风格 的 注释 。Shell 风格 的 注释 以 “#” 开 始 ,可 以 放 在 行 首 也 可 以 放 在 行 
尾 , 注 释 内 容 可 以 为 多 行文 字 , 以 回 车 符 作 为 注释 的 结束 。Shell 风格 注释 内 容 中 不 能 出 
现 “? > "标志 ,因为 解释 器 会 认为 PHP 脚本 到 此 结束 ,从 而 出 现 程序 错误 。 
【 例 8.8】 Shell 风格 的 程序 注释 。 
<?PHP 
症 义 常量 PT, 其 值 为 3.1415926, 使 用 该 常量 时 不 区 分 大 小 写 
Define ("PI", "3.1415926",True) ; 
Echo 10* pi; 握 示 计算 结果 : 31.415926 
2> 


4. 散 入 PHP 程序 文件 


在 网 络 程序 设计 过 程 中 ,往往 将 多 处 需要 重复 执行 的 程序 代码 设计 成 一 个 PHP 文 
件 , 称 为 被 嵌入 的 PHP 程序 文件 , 当 需 要 执行 被 戏 入 文件 中 的 程序 时 ,调用 Include( ) 或 
Require( ) 函数 即 可 。 

函数 格式 : 

Require (被 戏 入 的 PHP 程序 文件 名 ) 

Include (被 嵌入 的 PHP 程序 文件 名 ) ; 

调用 两 个 函数 时 都 可 以 省 略 括号 ,但 函数 名 与 参数 之 间 至 少 要 有 一 个 空格 。 其 中 被 
典 入 的 PHP 程序 文件 名 是 一 个 字符 串 , 包 含 文件 路 径 文件 主 名 及 扩展 名 ,省 略 文件 路 
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径 , 表 示 被 蔡 入 的 PHP 程序 文件 与 当前 PHP 程序 文件 同 路 径 。 

两 个 函数 的 功能 基本 相同 ,在 一 个 PHP 程序 文件 中 ,可 以 多 次 调用 这 两 个 函数 , 甚 
至 ,对 同一 个 PHP 程序 文件 也 可 以 嵌入 多 次 。 

两 个 函数 的 区 别 在 于 : 若 被 嵌入 的 程序 中 存在 错误 ,Require( ) 会 在 显示 致命 错误 信 
息 后 终止 执行 程序 ,而 Include( ) 显示 警告 信息 后 能 够 继续 执行 程序 。 

【 例 8.9】 设计 文件 footer. php ,其 内 容 显示 一 行 版 权 信 息 ; 设 计 文件 tp. php ,其 嵌入 
使 用 footer. php 文件 显示 版 权 信 息 。 

(1) 设计 PHP 文件 footer. php。 启 动 Apache 服务 ,在 配置 好 的 站 点 中 , 单 击 “ 文 件 ” 
菜单 一 "新建" 一 选择 页 面 类 型 PHP 一 “创建 "按钮 ,在 代码 视图 中 选中 并 删除 全 部 示例 代 
码 后 输入 如 下 代码 : 

<?2PHP 


Echo " <p Align ='center' >Copyright (© 2010 " .date ("Y") . 
"” WAW.RCZP.COM </p >"; 





(2) 同样 方法 创建 PHP 文件 tp. php ,输入 如 下 代码 : 


<HIML ><Head > 
<Meta HTTP Equiv ="Content -Type" Content ="Text/HIML; Charset =UTF -8" /> 
<Title > 人 才 招 聘 首页 </Title ></Head > 
<Body > 
<HL 次 迎 访问 人 才 招 聘 网 站 首页 ! </ 醒 > 
< 也 > 人 才 招 聘 网 站 已 经 开通 </P> 
< 湘 关 资 料 正在 完善 中 …… </P> 
<?PHP Include ('footer.php'); // 嵌入 并 执行 footer.php 中 的 程序 代码 ?> 
</Body > </HIML > 


(3) 查看 页 面 结果 。 在 tp. php 文件 编辑 窗口 , 单 击 文档 工具 栏 中 * 在 浏览 器 中 预览 / 
调试 "图 标 一 “预览 在 IExplore "选项 ,在 正 中 查看 tp. php 的 执行 效果 。 

与 Require( ) 和 Include( ) 两 个 函数 对 应 ,PHP 中 还 有 Require_once( ) 和 Include_once 
() 两 个 函数 ,与 前 两 个 函数 比较 ,其 参数 要 求 相同 ,函数 的 功能 类 似 。 区 别 仅 在 于 ; 在 一 
个 PHP 程序 文件 中 ,对 同一 个 被 嵌入 的 PHP 程序 文件 ,前 两 个 函数 可 以 嵌入 多 次 ,而 后 两 
个 函数 仅 能 能 入 一 次 。 


8.3 PHP 与 HTML 的 区 别 及 关联 


HTML 是 超 文本 标记 语言 ,是 所 有 网 页 制作 技术 的 基础 ,无 论 是 展示 信息 的 静态 网 
页 ,还 是 提供 交互 功能 的 Web 程序 ,都 离 不 开 HTML 语言 。PHP 是 一 种 可 租 入 到 HTML 
中 的 脚本 语言 ,运行 在 服务 器 端 ,提供 动态 网 页 支持 。 

在 网 页 设计 中 ,HTML 代码 与 PHP 代码 可 以 相互 嵌入 ,用 来 实现 复杂 应 用 。 
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1. PHP 代码 骨 入 HTML 代码 中 
【 例 8.10】 程序 界面 显示 时 间 。 


<HL > 
<? PHP 
Date _ Default TimeZone Set('PRC'); // 设 置 时 区 
Echo "现在 是 ".Date ("H:i:s"); // 输 出 时 间 
gS 
</ 卫 > 


在 该 程序 中 , < Hl1 > 和 </Hl > 是 HTML 代码 ,“<?PHP” 与 “? > "是 PHP 代码 。 本 
例 PHP 代码 能 入 HTML 代码 中 。 用 Dreamweaver 创建 PHP 应 用 程序 就 是 将 PHP 代码 骨 
入 HTML 代码 <Body > 与 </Body > 主体 标签 中 。 


2. HTML 代码 嵌入 PHP 代码 中 
【 例 8.11】 程序 界面 显示 文字 。 


<?PHP 
Echo " < > 人 才 招 聘 管 理 系统 </p >"; 
二 
其 中 <p > 人 才 招聘 管理 系统 </p > 是 HTML 代码 ,其 出 现在 PHP 的 输出 语句 中 。 
3. 将 HTML 代码 当成 字符 串 在 PHP 程序 中 输出 


在 程序 中 ,如 果 PHP 代码 和 HTML 代码 频繁 交 蔡 出 现 , 则 需要 多 次 使 用 定 界 符 关闭 和 
开始 一 段 PHP 代码 ,将 HTML 代码 当成 字符 串通 过 PHP 程序 输出 ,可 以 避免 这 个 问题 。 

【 例 8.12】 程序 界面 显示 不 同 大 小 的 文字 。 

(1) 启动 Dreamweaver, 单 击 “ 文 件 " 菜 单一 “新 建 ”" 选 项, 在“ 新建 文档” 界面 中 选择 
“空白 页 ” ,在 给 出 的 “页 面 类 型 "中 选择 PHP, 单 击 “ 创 建 "按钮 。 

(2) 在 “代码 "视图 中 标签 < Body > 和 </Body > 之 间 输 入 如 下 程序 代码 : 

中 涉 同 字号 文字 的 输出 </p > 

<?2PHP 

For (m=1; 和 <8; Mnm+) 
Echo " <Font Size=". 和 ." 第". 和 ." 次 发 布 招聘 信息 ! </Font ><br >"; 

> 

(3) 单 击 “ 文 件 "菜单 一 “保存 "选项 ,在 “另存 为 "对 话 框 中 输入 文件 名 EXP8_4. PHP， 
保存 程序 。 

(4) 单 击 “ 在 浏览 器 中 预览 /调试 "选项 ,选择 “预览 在 IExplore” , 页面 运行 结果 如 
图 8-2 所 示 。 


(5) 从 图 8-2 所 示 的 浏览 器 右 击 菜单 中 选择 “查看 源 "选项 ,显示 页 面 对 应 的 HTML 
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的 源 代码 ,如 图 8-3 所 示 。 


(DO e/ato po - se 国 寺村 
| 文件 日 ”篇 各 可 看 VW) 收 训 夫 (A) 工具 中” 帮助 (H) 


不 同 字号 文字 的 输出 








茵 1 次 发 布 招 稳 信 息 
宙 扫 信息! 
3 次 发 布 招聘 信息 ! 


第 4 次 发 布 招聘 信息 ! 
第 5 次 发 布 招聘 信息 ! 


第 6 次 发 布 招聘 信息 ! 
第 7 次 发 布 招聘 信息 ! 


图 8-2 PHP 程序 间接 生成 的 网 页 











ETTTTCTTTRCCCR 和 和 
文件 昌 ”编辑 (E) 格式 (O) 

《IDOCTYPE html PUBLIC “-//W3C//DTD XHMTWL 1.0 Transitional//EN" 

“http: /fmme. w3, org/TR/xhtml1/DTD/xhtnl1-transitional. dtd”> 

htnl xmlns="http://ww. w3. org/1999/xhtnl”> 

head> 

neta http-equiv="Content-Type” content="text/html; charset=utE-8” /> 
《title) 湛 标题 文档 Ytitle> 

Shead> 








hody> 
印 ) 环 同 字号 文字 的 输出 fp> 


Sooamnmnomwmewn 


Gont Sire=1; 第 1 次 发 布 招聘 信息 ! </Font>Gbr>Gont size=2y 第 2 次 发 布 招聘 信息 ! </Font>cbry| 

他 ont Size=3) 第 3 次 发 布 招聘 信息 ! 《Font>Qbr>GFont Size=4; 第 4 次 发 布 招聘 信息 ! 《JFont>Cbr>| 
人 Pont Size=5? 第 5 次 发 布 招聘 信息 ! 《Font>Gr>Gont Size=6) 第 6 次 发 布 招聘 信息 ! </Font>cbry| 
| Gent Size=7) 第 7 次 发 布 招聘 信息 !《/Font><br> 

| Ybody> 

| Yhtnl> 











图 8-3 PHP 程序 直接 生成 的 HTML 源 代码 


从 图 8-3 可 以 看 出 ,运行 PHP 程序 直接 生成 的 结果 是 HTML 的 源 代 码 , 再 由 浏览 器 
解析 后 才 变 成 网 页 信息 。 因 此 ,设计 PHP 程序 的 主要 目的 是 动态 地 生成 网 页 ,使 网 页 信 
息 随 着 时 间 和 用 户 的 不 同 而 变化 。 


8.4 变量 及 表达 式 


表达 式 是 程序 完成 各 种 运算 的 基本 工具 ,变量 是 表达 式 中 的 重要 元 素 。 变 量 是 程序 
运行 过 程 中 随时 可 能 发 生变 化 的 量 ,是 程序 中 存储 数据 的 基本 单元 。 通 过 名 字 标 识 变量 ， 
系统 为 每 个 变量 分 配 一 段 存储 空间 ,程序 借助 变量 名 可 以 访问 内 存 中 的 数据 。 
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8.4.1 变量 的 定义 及 引用 


在 PHP 中 ,变量 名 必须 以 字符 “$ "开头 ,最 多 可 以 254 个 汉字 .英文 字母 .数字 和 下 
画 线 , 但 是 ,第 二 个 字符 不 能 是 数字 ,英文 字母 严格 区 分 大 小 写 。 例 如 , $ xuehao、$ 学 号 、 
$_bm 和 $_1 都 可 以 作为 变量 名 ,而 $ 5S_A、$ xue hao 和 $% AB 都 不 能 作为 变量 名 ; $ 
Name 、$ NAME 和 $ name 是 3 个 不 同 的 变量 名 。 

PHP 采用 弱 数 据 类 型 , 即 PHP 变量 无 特定 的 数据 类 型 ,通过 为 变量 赋值 即 可 定义 变 
量 ,赋值 时 表达 式 的 数据 类 型 即 为 变量 的 数据 类 型 ,并且 随 着 值 的 变化 而 改变 。 

赋值 语句 格式 : 


变量 名 = 表达 式 


引用 变量 就 是 在 表达 式 中 使 用 变量 的 值 。 在 引用 变量 之 前 ,必须 先 赋值 (定义 ) ,和 否 
则 ,程序 运行 时 将 出 现 错误 。 


8.4.2 表达 式 及 其 输出 


1. 表达 式 


表达 式 是 构成 PHP 程序 的 基本 元 素 ,最 基本 的 表达 式 是 常量 和 变量 。 通 常 表 达 式 中 
可 以 包含 常量 .变量 .函数 名 ,运算 符 及 小 括号 等 。 通 过 系统 函数 可 以 测试 表达 式 的 数据 
类 型 。 

函数 格式 : 

GetType (表达 式 ) 

函数 返回 代表 数据 类 型 的 英文 名 字符 串 ,例如 , Integer( 整 型 ) Double( 实 型 )、 
Boolean( 逮 辑 型 或 布尔 型 ) String( 字 符 串 型 ) Array( 数 组) 或 Object( 对象) 等 。 

【 例 8.13】 表达 式 举 例 。 


<?PHP 
银 万 ; // 定义 银 为 整 型 变量 , 值 为 5 
姑妈 .14 * 银 * 银 ;  // 表 达 式 中 引用 变量 泉 , 计 算 圆 的 面积 78 .5 存 于 变量 $6 
名人 才 招聘 "; // 字符 常数 构成 表达 式 ,将 人才 招聘 " 存 于 变量 短 


得 = 得 ." 网 站 "; // 由 “ ." 运 算 符 连接 变量 知 和 常数 ,用 “人 才 招 聘 网 站 "改变 得 的 值 
倒 = 圆 的 面积 为 :". $6 ; // 对 全 重新 赋值 ,同时 改变 其 数据 类 型 为 字符 串 





时 


2. 输出 表达 式 的 值 


PHP 程序 输出 的 数据 往往 是 HTML 文件 中 的 信息 和 标签 ,再 由 浏览 器 解析 出 网 页 中 
的 信息 。 设 计 PHP 程序 时 ,将 HTML 中 的 标签 作为 一 个 字符 串 或 表达 式 的 一 部 分 ,常用 
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Echo 输出 表达 式 的 值 。 
语句 格式 : 
Echo 表达 式 表 
表达 式 表 是 由 逗号 分 隔 的 多 个 表达 式 构成 的 , 当 只 有 一 个 表达 式 时 ,可 将 Echo 作为 
函数 调用 , 即 用 小 括号 将 表达 式 括 起 来 。 
【 例 8.14】 输出 连接 的 字符 串 及 HTML 标签 <br> 。 
<2PHP 
Sstrl =" 欢 迎 使 用 "; $str2 "人才 招聘 数据 库 "; 
Echo ( $str1."". $str2.' <br >'); // 作为 函数 调用 ,参数 为 圆 点 连接 的 一 个 表达 式 
// 结果 : 欢迎 使 用 人 才 招 聘 数 据 库 
Echo $strl."", $str2.' zor >'; ”// 逗号 分 隔 两 个 表达 式 , 不 能 用 括号 
Snum3.14; 
Echo Gettype ( Shum) ,，";"，Gettype ("T 值 为 ". $num); ”// 输出 : double ; string 
2> 


执行 Echo 输出 逻辑 型 数据 时 ,True( 真 ) 输 出 1, 而 False( 假 ) 没 有 输出 数据 。 

3. 输出 表达 式 的 数据 类 型 及 值 

函数 格式 : 

Var Dump( 表达 式 1 [, 表达 式 2 [,……, 表达 式 n]] ) 

函数 自身 返回 值 为 NULL, 因此 通常 用 于 输出 各 个 参数 表达 式 的 数据 类 型 及 其 值 。 


表达 式 为 数组 名 时 ,输出 数组 中 每 个 元 素 的 数据 类 型 及 值 。 
【 例 8.15】 输出 表达 式 的 数据 类 型 及 值 。 


<?PHP 
$_DATE ="2016 -10 -01"; // 定义 $_DATE 为 字符 串 变量 
SZZ rue; // 定义 $22 为 逻辑 型 变量 
Sbai 3.14; // Spai 赋值 为 3.14 
殷 瑟 ; // 银 赋 值 为 5 


Var Dump ( Spai * $MR* $MR, $ DATE, $22); 
// 输出 结果 : float (78 .5) string (10) "2016 10 -01" bool (true) 


8.4.3 输入 变量 的 值 


PHP 中 变量 的 值 可 以 通过 赋值 方式 给 定 ,也 可 以 通过 用 户 交 互 方式 获取 。 通 过 浏览 
器 中 的 表单 控件 是 程序 获取 用 户 数据 的 一 种 常用 方法 。 通 过 PHP 提供 的 超 全 局 关联 数 
组 ,程序 可 以 获取 表单 控件 上 用 户 输入 的 数据 。 
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1. 检测 变量 的 函数 

在 程序 获取 表单 控件 上 的 数据 之 前 ,需要 捕捉 用 户 提交 数据 的 时 机 ,其 中 一 种 方法 是 
调用 PHP 的 IsSet( ) 函数 分 析 用 户 是 否 提交 数据 。 

函数 格式 

IsSet (变量 名 1[, 变 量 名 2 [,……, 变 量 名 n]]) 

如 果 每 个 变量 都 有 定义 并 且 值 不 为 Null, 则 函数 返回 值 为 1( True) ; 若 某 个 变量 未 定 
义 或 者 值 为 Null, 则 函数 返回 值 为 False。 

【 例 8.16】 检测 变量 是 否 有 值 。 


<?PHP 
Sstrl = 数据 库 ";” 乱 导 23; 
Echo Isset( $strl) ." <br>"; // $strl 有 定义 且 不 为 NULL, 返 回 结果 true, 显示 1 
Echo Isset ($strl, $4)." dr/>;  // $strl 和 扰 都 有 定义 上 且 不 为 NULL, 返 回 true, 显示 1 
Var dump (Isset ( $c)); // 氏 未 定义 ,返回 结果 false， 显 示 bool (false) 

2> 


2. 接收 表单 控件 的 数据 


在 浏览 器 的 表单 上 用 户 单 击 “提交 ”按钮 后 ,PHP 程序 可 以 通过 超 全 局 关联 数组 $ _ 
POST 接收 表单 控件 上 的 数据 。 提 交 表 单 就 会 刷新 网 页 ,而 刷新 网 页 就 是 重新 执行 一 次 页 
面 中 的 所 有 代码 。 

【 例 8.17】 设计 如 图 8-4 所 示 的 表单 ,通过 交互 方式 获取 变量 的 值 。 


®) 加 htpy/iocalhost/php_ ~ | 


文件 旧 ”编辑 查看 (VW) 收 基 夫 (A) 工具 中 











变量 1] 














变量 2: 提交 
变量 1 中 的 值 : 10 
变量 2 中 的 值 : 20 
10+20=30 

















图 84 输入 数据 应 用 


设计 过 程 如 下 : 
(1) 用 Dreamweaver 创建 PHP 文档 ,在 “代码 "视图 中 的 < Body > 和 </Body > 标签 
之 间 输 入 如 下 程序 代码 来 设计 表单 及 其 控件 : 


<Form Method ="post" Action ="" > 
变量 1: <Input Type ="text" Name 2"al" Size 2"12" ><br > 
变量 2: <Input Type ="text" Name ="a2" Size 一 12" > 
<Input Type =submit" Name "tijiao" Value 一 "提交 "> 
</Fom> 
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<?2PHP 


If(IsSet ($ POST["tijiao"])) { // 判断 是 否 单 击 了 提交 按钮 
Sal =$ POST["al"]; // 用 超 全 局 关联 数组 $ POST 提取 表单 中 al 控件 的 值 , 存 于 变量 $a1 中 
Sa2 =$ POST["a2"]; // 提取 表单 中 a2 控件 的 值 , 存 于 变量 $a2 中 


Echo "变量 1 中 的 值 : ". $al." <zbr >"; ”// 显示 变量 $al 
Echo "变量 2 中 的 值 : ". Sa2." <br >"; // 显示 变量 $a2 
Echo " Sal +Sa2 =". ( $al + $a2); // 计算 $al +$a2 的 值 并 显示 } 
?> 
(2) 单 击 “ 在 浏览 器 中 预览 /调试 "选项 ,选择 “预览 在 正 xplore "选项 ,在 浏览 器 页 面 
中 分 别 输入 值 10 与 20 后 , 单 击 “提交 "按钮 ,页 面 运行 结果 如 图 84 所 示 。 
(3) 从 图 84 所 示 浏 览 器 的 右 击 菜单 中 选择 “查看 源 " 选 项 ,显示 页 面 对 应 的 源 代 码 ， 
如 图 8-5 所 示 。 











羡 httpy/ocalhost/wssd/exp8_16.php - 原 汉 当 es)| 


文件 昌 ”编辑 (E) 格式 (O) 
1 | 4DoCTYPE htnl PUBLIC “~//W3C//DTD ITNL 1.0 Transitionel /EN" 
“http: /fwww. w3. org/TR/xhtnl1/DTD/xhtnll-transitional. dtd”> 





2 | htnl xmlns="http://wew. w3. org/1999/xhtnl”> 

3| head> 

4 | 人 eta http-equiv="Content-Type” content="text/html; charset=utf-8" /> 
5 | <title> 无 标题 文档 人 title> 

6 | Yhead> 

7 

8 


| body> 
日 | CForm Nethod="post” Action=""> 
10 | 变量 1: dnput Type="text” Nane="al” Size="l2">Cbr /> 
11 | 变量 2: dnput Type="text” Namne="a2” Size="1l2” > 











12| nput Type="subnit” Nane="tijiao” Yalue=" 提 交 ” > 
13| YForn> 
14 | 变量 1 中 的 值 ;: 10Qr) 变 量 2 中 的 值 : 20 人 br>10+20=30 
45 | 
| 
16 | Ybody> 
17 | Yhtml> 











图 8-5 表单 控件 源 代码 及 输出 结果 


8.5 字符 串 表 达 式 


在 Web 程序 设计 中 ,正确 地 使 用 和 处 理 字符 串 , 对 于 程序 设计 来 说 至 关 重要 。 字 符 
串 表 达 式 是 字符 串 运算 符 连接 字符 型 数据 的 运算 式 ,运算 结果 仍然 是 字符 串 型 数据 。 


8.5.1 字符 串 


1. 字符 串 常数 

字符 串 是 由 0 或 多 个 字符 构成 的 符号 集合 ,在 PHP 程序 中 通常 用 半角 单 引 号 (' ) 或 
双 引 号 (" ) 将 字符 串 常数 引起 来 。 

【 例 8.18】 字符 串 赋值 举例 。 
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po 


ee 


<2PHP 
// 半角 双 引号 引起 来 字符 串 , 将 HIML 的 标签 <br 3 作为 常数 


Sstrl 人才 招 聘 br >"; 

$str2 =' 数 据 库 '; // 半角 单 引号 引起 来 字符 串 常 数 
Echo $strl; // 输出 : 人 才 招 聘 

Echo $str2; // 输出 : 数据 库 


2. 单 引 号 与 双 引 号 的 区 别 
双 引 号 中 的 字符 串 含 变量 名 ,系统 自动 用 变量 的 值 蔡 换 变 量 名 ,除非 变量 名 前 加 ”\” 
符号 ; 单 引 号 中 的 字符 串 含 变量 名 ,变量 名 就 是 字符 串 中 的 字符 ,并 不 替换 其 值 。 
【 例 8.19】 单 引号 与 双 引号 的 区 别 举例 。 


<?PHP 
Sstrl = 数据 库 "7 
Echo "人 才 招 聘 Sstrl"." <br >"; 
Echo "人 才 招 聘 \Sstrl"." <br >"; 
Echo ' 人 才 招 聘 $str1'." <br >"; 


// 双 引 号 替换 $strl 的 值 ,显示 : 人 才 招 聘 数据 库 
// 变量 名 前 加 *' ,不 替换 其 值 ,显示 : 人 才 招 聘 $strl 
// 单 引 号 不 替换 Sstrl 的 值 ,显示 : 人 才 招 聘 Sstrl 


3 


3. 转 义 符号 
转 义 字符 通常 用 于 网 络 日 志 的 书写 中 。 例 如 ,输出 的 双 引 号 字符 串 中 含有 换行 符 ( \n) 
时 ,浏览 絮 会 将 换行 符 修改 成 空格 ,只 有 查看 网 页 源 代码 时 才能 看 到 换行 符 的 效果 。 出 现 
在 单 引 号 字符 串 中 的 转 义 符号 不 具有 特殊 意义 ,系统 原样 输出 。 常 用 的 转 义 符号 如 
表 8-1 所 示 。 
表 8-1 常用 的 转 义 符号 


























转 义 字符 输出 转 义 字符 输出 
\n 换行 \$ 美元 符号 
\r 回 车 Vv 单 引号 
At 水 平 制 表 符 区 双 引 号 
\\ 反 斜 杠 
4. 空格 的 处 理 


浏览 器 通常 会 对 字符 串 中 的 空格 进行 过 滤 处 理 。 当 字符 串 中 含有 连续 多 个 空格 时 ， 
浏览 器 页 面 中 默认 只 显示 一 个 ; 当 若干 空格 出 现在 字符 串 的 左 侧 时 ,直接 忽略 不 显示 。 若 
要 显示 多 个 空格 , 则 要 用 符号 &nbsp 表示 。 

【 例 8.20】 含 空格 字符 串 的 输出 效果 。 


<?PHP 
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Sstrl ”人 才 招聘 系统 
Sstr2 ”人 才 gnbspgnbspgnbsp 招聘 系统 


Echo $strl, " <r»>"; // 在 浏览 器 中 去 掉 多 余 的 空格 ,显示 : 人 才 招聘 系统 
Echo S$str2, "br>"; // 在 浏览 器 中 显示 结果 : 人 才 ”招聘 系统 


8.5.2 字符 串 的 连接 符 


半角 句号 “. "是 字符 串 连接 运算 符 , 用 来 将 两 个 或 两 个 以 上 的 字符 串 连接 成 一 个 新 
的 字符 串 。 如 果 参 与 连接 的 操作 数 不 是 字符 串 类 型 , 则 系统 会 将 其 转换 为 字符 串 类 型 后 
再 进行 连接 操作 。 
【 例 8.21】 连接 字符 串 。 
<?PHP 
S$trl ="PHP"; 
Str2 "编程 语言 "; 
Echo Strl. 人 Str2; ”// 结 果 字 符 串 "PHP 编程 语言 " 
Echo " <br >"; 
Echo $trl. 6; // 结 果 字 符 串 "PHP6", 连 接 内 容 是 数字 , 则 运算 符 "." 后 加 空格 分 隔 


8.5.3 字符 串 常用 函数 
1. 去 除 字符 串 首尾 空格 和 特殊 字符 
函数 格式 : 


Trim(str [,charlist]) 

函数 说 明 : Trim 函数 用 于 去 除 str 字符 串 首尾 空格 和 特殊 字符 ,并 返回 去 掉 空格 和 特 
殊 字符 后 的 字符 串 。 特 殊 字 符 包括 空 值 (\0) \ 制 表 符 (\t) ` 回 车 符 ( \r) .换行 符 ( \n) 及 空 
格 等 。 

参数 charlist 为 字符 串 数据 ,如 要 删除 str 字符 串 首尾 出 现 的 某 些 字符 可 将 其 放 入 
charlist 字符 串 中 ,charlist 参数 中 的 字符 没有 顺序 关系 。 当 使 用 该 参数 时 ,Trim 不 再 删除 
字符 串 首尾 的 空格 及 特殊 字符 。 

【 例 8.22】 去 除 字 符 串 首尾 字符 

<2PHP 


Sstrl ”PHP 编程 语言 PHP \n"; 
$str2 ="PHP 编程 语言 PHP"; 


Echo Trim( Sstrl) ." <br >"; // 结 果 为 字符 串 "PHP 编程 语言 PHP" 
Echo Trim( Sstr2,"PH") ." <br >"; // 结果 为 字符 串 " 编程 语言 
Echo Trim( $str2, "HP") ." <br >"; // 结果 为 字符 串 " 编程 语言 " 
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Echo Trim( Sstrl,"PH") ."<br >"; // 结果 为 字符 串 " PHP 编程 语言 PHP  \n" 
全 闫 


2. 去 除 字符 串 左边 的 空格 和 特殊 字符 
函数 格式 : 
Ltrim(str [,charlist]) 


函数 说 明 : 用 于 去 除 str 字符 串 左 边 的 空格 和 特殊 字符 ,其 余 同 Trim 函数 。 
【 例 8.23】 去 除 字符 串 左 侧 空格 和 特殊 字符 。 


<?PHP 
Strl=" PHP 编程 语言 PHP mo"; 
Echo Ltrim( $tr1)." or >"; // 结 果 字 符 串 "PHP ”编程 语言 “PHP n" 
Echo Ltrim(Trim( 今 tr1),"P") ." <dbr >"; ”// 结 果 字 符 串 "HP ”编程 语言 ”PHP" 

SS 

3. 去 除 字符 串 右边 的 空格 和 特殊 字符 

函数 格式 : 


Rtrim(str [, charlist]) 


函数 说 明 : 用 于 去 除 str 字符 串 右 边 的 空格 和 特殊 字符 ,其余 同 Trim 函数 。 
【 例 8.24】 去 除 字符 串 右 侧 空 格 和 特殊 字符 。 


<?PHP 
Strl ="， PHP 编程 语言 PHP mn" 
Echo Rtrim( $tr1); // 结 果 字 符 串 " ”PHP 编程 语言 "PHP" 
Echo " <br >"; 
Echo Rtrim(Trim( Str1), "P"); // 结 果 字符 串 "PHP ”编程 语言 “PH" 
2> 


4. 获取 字符 串 长 度 

函数 格式 : 

Strlen (str) 

函数 说 明 : 返回 值 是 str 字符 串 中 所 含 字符 的 个 数 ,空格 也 计算 在 内 。 英 文 符号 长 度 
为 1, 汉 字 长 度 与 所 用 的 字符 集 ( 编码 ) 相关 ,例如 ,UTF-8 字符 集 每 个 汉字 或 全 角 符 号 长 
度 为 3,GB2312 字符 集 每 个 汉字 或 全 角 符号 的 长 度 为 2。 

【 例 8.25】 计算 字符 串 长 度 。 


<2?PHP 
Echo Strlen ("PHP 网 络 编程 语言 ") ; // 输出 结果 : 21 
人 
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5. 截取 字符 串 

函数 格式 : 

Substr (str, n [,m]) 

函数 说 明 : 从 字符 串 str 的 第 n 个 字符 位 置 开始 , 取 长 度 为 m 的 子 串 。 字 符 串 str 中 
第 1 个 字符 的 位 置 为 0, 第 2 个 字符 位 置 为 1, 其余 类 推 。 如 果 省 略 长 度 m, 则 取 第 n 个 位 
置 开 始 至 结尾 的 全 部 字符 。 

【 例 8.26】 截取 字符 串 。 


<?PHP 
$trl ="2016 -12 0"; 
Echo Substr ( $trl, 2); // 结 果 : 16 -12 10 
Echo Substr ( $trl, 2,4); // 结 果 : 16 工 


Echo Substr( Strl, 2, -3); ” // 结 果 : 16 -12 长 度 为 负 , 表 示 取 到 倒数 m | 位 置 前 的 内 容 
Echo Substr( Strl，-2,2)7 // 结 果 : 10 开始 位 置 为 ,倒数 In | 开始 
2> 


6. 比较 字符 串 
函数 格式 : 
Strcmp (strl, str2) 
函数 说 明 : 函数 返回 两 个 字符 串 strl 和 str2 的 比较 结果 。strl 小 于 st2 ,比较 结果 为 
一 1 ;strl 等 于 str2 ,结果 为 0;strl 大 于 str2 ,结果 为 1 。 
【 例 8.27】 字符 串 比 较 。 
<?2PHP 
Str] ="hello"; $tr2 ="Hello"; 
Echo Strcmp ( Strl, $tr2); // 结 果 : 1 
Bcho ™ <br > 
Echo Stramp ( $trl, "hello"); // 结 果 : 0 
Echo " <br >"; 
Echo Stramp ("abc", "adcm) // 结 果 : 工 
?> 


7. 检索 字符 串 
函数 格式 : 
Strstr{strl, str2) 


函数 说 明 : 从 strl 字符 串 中 查找 sn2 字符 串 的 内 容 。 若 找到 , 则 返回 找到 位 置 开始 
的 全 部 内 容 ; 如 果 未 找到 , 则 函数 返回 false。 
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【 例 8.28】 检索 字符 串 。 
<2PHP 
外 trl ="abcabcdel23"; 
Echo Strstr ( Strl, "abcd"); // 结 果 : abcde123 
Echo "<br >"; 
Echo Strstr ( $trl, "abc"); // 结 果 : abcabcde123 
Echo " <or >"; 
Sa =Strstr ( Strl, "ad"); // 函 数 返 回 值 false 
Var Dump ( Pa); // 显 示 变 量 a, 结果 : bool (false) 


?> 
8. 生成 重复 串 函数 

函数 格式 : 

Str Repeat (strl, n) 

函数 说 明 : 参数 strl 为 一 字符 串 ,n 为 重复 次 数 ,其 值 为 大 于 或 等 于 0 的 整数 。 若 n 


值 为 实数 , 则 系统 自动 转换 为 其 对 应 的 整数 值 。 
【 例 8.29】 重复 字符 串 。 


<?PHP 

$strl =" —"; 

$str2 下 人 才 ".str_repeat ( Sstrl,10) ." 招 聘 "; 

Echo S$str2; // 结果 : 人 才 --------- -招聘 
E 


8.6 数值 型 表达 式 


表达 式 是 运算 符 连 接 常数 ,变量 和 函数 等 运算 对 象 所 构成 的 运算 式 。 运 算 符 是 对 数 
据 进行 操作 的 符号 。 运 算 结 果 为 数值 型 数据 的 表达 式 称 为 数值 表达 式 。 


8.6.1 常量 


常量 是 程序 运行 过 程 中 其 值 不 发 生变 化 的 量 ,PHP 中 数值 型 数据 分 为 整 型 和 浮 点 型 
两 种 。 整 型 数据 只 能 包含 整数 。 整 型 可 以 用 十 进 制 .八进制 和 十 六 进 制 来 表示 。 八 进 制 
数值 前 加 0, 十 六 进 制 数值 前 加 0x。 

浮 点 型 数据 可 以 保存 小 数 , 有 两 种 书写 格式 : 一 种 是 直接 书写 ,如 123.5、- 10. 8、 
3. 14159 等 ; 另 一 种 是 科学 记 数 格式 ,如 1.235E2 表示 123.5,1.25E -3 表示 0.00125。 
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8.6.2 数值 运算 符 


数值 运算 符 是 处 理 数值 运算 的 符号 ,运算 结果 为 数值 型 数据 。 常 用 的 数值 运算 符 如 
表 8-2 所 示 。 
































表 8-2 ”数值 运算 符 
运算 符 说 明 举例 运算 符 说 明 举例 

十 加 法 运算 $a+t+ $b % 整数 求 余数 运算 | $a9% $b 
一 减法 运算 $a—- $b 十 十 增 1 操作 $at++ ++$a 
* 乘法 运算 $ax $b 一 一 减 1 操作 $a-- ——-$a 
这 除法 运算 $a/ $b 一 取 负 -$a 
【 例 8.30】 数值 数据 运算 。 
<?PHP 

捍 -80; 和 20; 

Echo ' ="'. ." <br >"; // 皇 -80 

Echo ' 则 ='. $." br >"; // P20 

Echo ' 锡 + 多 ="'.( 锡 + 和 9) ." <br >"; // 捍 + 多 习 00 

Echo ' 锡 -多 ="'. (和 锡 -9)." <br >"; // 皇 -多 =60 

Echo ' * $='. (A* $9)." br >"; // 自 * 多 导 600 

Echo ' §/ $=". (hd/ 9)." br>"; // 和 /和 则 对 

Echo ' hs% P="'. (Ns%9)." br >"; // sD 

Echo ' - 锡 =".(-)." br>"; //- 锡 =-80 

Echo ' ++="'. 旬 ++." <br >"; //++=80 

Echo ' 运 算 后 的 锡 值 为 : '. 旬 ." <br >"; // 运 算 后 的 锡 值 为 : 81 

Echo ' ++ 鲍 ='. ++ 钨 ." <br >"; //++ 锡 -82 

Echo ' 运 算 后 的 皇 值 为 : '. 旬 ." <br >"; // 运 算 后 的 丘 值 为 : 82 

Echo ' 皇 --='. 皇 ---"<bryn; // 丘 ---82 

Echo ' 运 算 后 的 自 值 为 : '. 自 ."<br >"; // 运 算 后 的 丘 值 为 : 81 

Echo ' -- 皇 ='. -- 皇 ."<br >"; // -- 皇 =0 

Echo ' 运 算 后 的 银 值 为 : '. 旬 ." br >"; // 运 算 后 的 刍 值 为 : 80 


2 六 


自 增 、 自 减 运算 符 可 以 放 在 变量 前 ( 称 前 级 ) ,也 可 以 放 在 变量 后 ( 称 后 缀 ) , 当 运 算 作 
为 独立 的 语句 时 ,做 前 级 与 做 后 级 功能 相同 。 例 如 , 设 $a=10, 执行 $a+ + 或 + + $a 
语句 都 使 变量 $a 的 值 增 1, 即 $a 的 值 为 11。 

但 自 增 、 自 减 运算 作为 表达 式 的 数据 项 时 ,前 缀 先 改 变 变 量 的 值 ,再 将 变量 的 值 作用 
于 表达 式 中 ;后 级 先 引 用 变量 的 值 ,再 改变 变量 的 值 。 例 如 , 设 $a=10, 执 行 语句 $b = 
$a+ + 后 ,$b 的 值 为 10, $a 的 值 为 11; 同 样 , 若 执行 语句 $b= + + $a; 后 ,$a 和 $b 
的 值 都 是 11。 
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8.6.3 运算 符 的 优先 级 与 结合 性 


运算 符 具 有 优先 级 的 概念 , 当 表 达 式 中 出 现 不 同 级 别 的 运算 符 时 , 先 执行 高 级 别 运算 
再 执行 低级 别 运 算 。 例 如 ,有 变量 定义 $ a=10; $ b=20; $ c=30; 则 执行 表达 式 $ d 
=$a+t+$bx$c; 后 $d 的 值 为 610, 因 为 该 表达 式 中 乘法 运算 ( x ) 的 级 别 最 高 ,加 法 
运算 ( + ) 次 之 ,而 赋值 运算 ( = ) 级 别 最 低 。 

运算 符 同样 具有 结合 性 的 概念 ,所 谓 的 结合 性 是 指 表 达 式 中 出 现 相同 级 别 运 算 符 时 
的 执行 顺序 , 若 运 算 符 为 左 结合 性 , 即 从 左 向 右 计算 ; 若 运算 符 为 右 结合 性 , 则 运算 从 右 至 
左 执行 。 例 如 ,乘法 和 除法 运算 为 同一 级 别 , 其 结合 性 为 左 , 则 表达 式 $ ax $ b/$c 的 
计算 顺序 是 先 计算 $ a* $ b, 再 用 $ a* $b 的 乘积 除 以 $ ec; 同样 赋值 运算 符 的 结合 性 
为 右 , 表 达 式 $ a= $b=1; 首 先 执 行 $ b =1; 之 后 再 执行 $ a =$ b; 即 $ a 的 值 同 样 
为 1。 

在 PHP 中 ,所 有 运算 符 都 有 优先 级 和 结合 性 的 定义 , 见 附 录 B 的 表 B-6。 


8.6.4 ”常用 数值 函数 


1. 取 绝 对 值 函 数 

函数 格式 : 

Abs (x) 

函数 说 明 : x 为 数值 型 表达 式 , 函 数 的 返回 值 为 x 值 的 绝对 值 ,返回 值 类 型 与 x 类 型 相同 。 
【 例 8.31】 Abs( ) 函数 应 用 。 


<?PHP 
锡 =-100; $=-123.23; 
Echo ' 锡 的 绝对 值 =' .Rbs ( 锡 ) ." <br >"; // 结 果 : 鱼 的 绝对 值 导 00 
Echo ' 多 的 绝对 值 =' .Abs ( 9) ." <br >"; // 结 果 : 多 的 绝对 值 23.23 
Echo ' 锡 + 多 的 绝对 值 =' .Abs ( 锡 +9) ." <br >"; 1/ 结果: 银 + 多 的 绝对 值 之 23.23 
> 


2. 四 舍 五 入 函数 
函数 格式 : 
Round (x [,prec]) 


函数 说 明 : 对 数值 x 按说 明 的 小 数位 数 prec 进行 四 舍 五 人 。 如 果 省 略 prec 参数 , 则 
prec 相当 于 0。Pprec 值 可 以 取 负 数 , 表 示 小 数 点 前 位 数 。 
【 例 8.32】 Round( ) 函数 应 用 。 


<?PHP 
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Echo Round (5.4) -" Zor >"; 

Echo Round (5.5) -" <br >"; 

Echo Round (5.6, 0)." <br >"; 

Echo Round (3.95565,，2) -" <br >"; 

Echo Round (2141723, 3)." br»>"; 
汪汪 


3. 向 下 舍 入 函数 
函数 格式 : 


Floor (x) 


函数 说 明 : 返回 小 于 或 等 于 x 值 的 最 大 整数 。 


【 例 8.33】 舍 和 信函 数 运算 。 


<?PHP 
Echo Floor (4.3) ." <br >"; 
Echo Floor (-9.89) ." <br >"; 
?> 


4. 向 上 舍 入 函数 
函数 格式 ， 


Ceil (x) 


函数 说 明 : 返回 大 于 或 等 于 x 值 的 最 小 整数 。 


【 例 8.34】 Ceil( ) 函数 应 用 。 


<?PHP 
Echo Ceil (4.3) ."<br >"; 
Echo Ceil( -9.89)." <br >"; 
2 


5. 开平 方 函数 
函数 格式 : 


Sart (x) 


// 结 果 : 5 

// 结 果 : 6 

// 结 果 : 6 

// 结 果 : 3.96 
// 结 果 : 2142000 


// 结 果 : 4 
// 结 果 : -0 


函数 说 明 : 函数 返回 数值 x 的 开平 方 结果 ,数值 x 要 求 为 非 负数 。 


【 例 8.35】 Sqrt( ) 函数 应 用 。 


<2PHP 
乍 导 24.25; 
Echo Sqrt (100) .-" <br >"; 
Echo Saqrt( 乍 萎 00) ."<br >"; 


// 结 果 : 10 
// 结 果 : 14.974979131872 
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(Go) 


> 


6. 求 最 大 值 和 最 小 值 函数 

函数 格式 : 

Mixed Max (mixed argl], mixed arg2 ,*…, mixed argn) 

Mixed Min (mixed argl, mixed arg2 ,*…, mixed argn) 

函数 说 明 : Max 函数 是 求 所 给 出 的 全 部 表达 式 值 的 最 大 者 。Min 函数 是 求 最 小 者 。 
各 表达 式 的 数据 类 型 必须 一 致 ,可 以 是 数值 型 .字符 串 型 .日 期 型 等 。 此 类 函数 可 以 有 多 
个 参数 ,通常 至 少 要 有 两 个 参数 。 如 果 仅 有 一 个 参数 日 为 数组 ,Max( ) 返 回 该 数组 中 最 大 
的 值 。Min( ) 函数 的 用 法 与 Max( ) 函数 相同 ,用 于 求 参 数 中 的 最 小 值 。 

【 例 8.36】 求 最 大 值 和 最 小 值 。 

<?PHP 


乍 刁 24.25; 多 性 00 .23; 
$trl ="abc"; $tr2 ="bcde"; $tr3="Abc"; 


Echo Max ( d, $) ." br >"; // 结 果 : 200.23 
Echo Min ( 自 ， 和 ,500) ." br >"; // 结 果 : 124.25 
Echo Maxz( ba Ptr2, St) "< // 结 果 : bcde 

2> 

7. 乘 方 函数 

函数 格式 : 

Pow (x, y) 


函数 说 明 : 返回 x 的 y 次 方 的 值 。 如 果 不 能 计算 值 ,函数 返回 Float 类 型 值 NAN。 
【 例 8.37】 Pow( ) 函数 应 用 。 


<?PHP 


Echo Pow (4,2) ." <br >"; // 结 果 : 16 
Echo Pow(-6,2) ." br>"; // 结 果 : 36 
Echo Pow( -6, -2) ." <br >"; // 结 果 : 0.027777777777778 
Echo Pow(-6,5.5) ."<br >"; // 结 果 : NAN 
和 


8.7 日 期 和 时 间 表 达 式 


在 程序 设计 中 ,日 期 和 时 间 是 非常 重要 的 ,通过 日 期 和 时 间 可 以 记录 登录 时 间 数据 


处 理 时 间 文件 操作 时 间 等 信息 ,保障 系统 安全 。 
在 PHP 中 表示 某 个 具体 日 期 时 间 可 以 使 用 Strtotime( ) 函数 实现 ,其 用 来 将 时 间 日 期 
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格式 字符 串 转换 为 UNIX 时 间 戳 ,再 通过 Date( ) 函数 控制 格式 转换 为 所 需要 的 日 期 时 间 
字符 串 。 

所 谓 时 间 戳 是 指 从 格林 威 治标 准时 间 1970 年 1 月 1 日 0 时 0 分 0 秒 到 指定 日 期 时 
间 所 经 过 的 秒 数 。 格 林 威 治标 准时 间 ( Greenwich Mean Time) 的 缩写 是 GMT, 是 英国 的 标 
准时 间 , 也 是 世界 各 地 时 间 的 参考 标准 。 英 国 时 间 比 中 国 的 北京 时 间 晚 8 小 时 。 

PHP 中 时 区 的 默认 设置 是 BST, 即 英国 夏 时 制 ( British Summer Time) ,其 比 格林 威 治 
标准 时 间 (GMT) 快 1 小 时 ,每 年 从 3 月 底 开始 ,到 10 月 底 结束 。 英 国 夏 时 制 期 间 , 中 英两 
国 的 时 差 为 7 小 时 。 

由 于 各 个 国家 所 在 时 区 及 时 间 管 理 上 的 差异 ,时 区 表示 格式 非常 之 多 ,例如 美国 时 区 
格式 有 US/Alaska 、US/Aleutian .US/Arizona .US/Central ,US/Eastern 和 US/Mountain 等 多 
种 ;加 拿 大 时 区 格式 有 Canada/ Atlantic .Canada/ Central .Canada/ Eastern .Canada/ Pacific 和 
Canada/ Saskatchewan 等 多 种 。 北 京 时 区 的 表示 有 “Etc/GCMT-8” 和 “PRC” 两 种 。 


1. 时 区 设置 函数 


在 PHP 中 设置 系统 时 区 可 以 用 函数 Date_Default_TimeZone_Set( ) , 函数 使 用 格式 
如 下 。 

Date_Default_TimeZone_Set( 时 区 格式 字符 串 ) 

【 例 8.38】 日 期 时 间 的 表示 。 

<?PHP 
$time ="1970 -01 -01 0:0:0"; // 定义 变量 外 ime, 存 储 日 期 时 间 格 式 字符 串 
Echo Strtotime ( $time) ." <br >"; 

// 显示 默认 时 区 下 变量 处 ime 对 应 的 时 间 戳 ,结果 : -3600 

Date Default_Timezone Set ("Etc/GMT'); // 设置 格林 威 治标 准时 区 


Echo Strtotime ( Stime) ."<br >"; // 显示 变量 $time 对 应 的 时 间 截 ,结果 : 0 

Date _ Default_ TimeZone Set ('PRC') 7 // 设置 北京 时 区 

Echo strtotime ( Stime) ."<br >"; // 显示 变量 $time 对 应 的 时 间 戳 ,结果 : -28800 
$time ="2017 2 40 10:10:10"; // 重新 设置 变量 $time 的 值 


Echo Strtotime ( $time) ."<br >"; // 显示 变量 $time 对 应 的 时 间 截 ,结果 : 1512871810 
Echo "设置 的 时 间 是 : ".Date ('Y 年 m 月 d 日 H 时 主 分 ',Strtotime (Stime))."<br >"; 
// 结果 : 设置 的 时 间 是 : 2017 年 12 月 10 日 10 时 10 分 


2. 日 期 和 时 间 函 数 
函数 格式 : 


Date (str[, stamp]) 


函数 说 明 : Date 函数 用 于 返回 日 期 或 时 间 。 参 数 stamp 是 要 获取 的 时 间 戳 值 , 省 略 
此 参数 , 取 系 统 当 前 时 间 戳 值 。st 用 于 设置 日 期 和 时 间 的 格式 串 , 各 个 格式 字符 的 含义 
如 表 8-3 所 示 。 


第 8 章 PHP 程序 设计 基础 


w 


表 8-3 ”Date 函数 的 格式 字符 及 其 说 明 












































格式 字符 说 明 格式 字符 说 明 
Y 以 4 位 显示 年 H 以 24 小 时 制 显 示 小 时 ( 补 零 ) 
3 以 2 位 显示 年 6 以 24 小 时 制 显 示 小 时 (不 补 零 ) 
而 以 2 位 显示 月 ( 补 堆 ) h 以 12 小 时 制 显示 小 时 ( 补 零 ) 
2 数字 量 示 月 (不 补 以 12 小 时 制 显示 小 时 (不 补 堆 ) 
M 以 英文 缩写 显示 月 i 以 2 位 数 显示 分 钟 ( 补 零 ) 
a 以 2 位 数 蔓 示 目 《 神 机 以 2 位 数 显示 秒 ( 补 零 ) 
j 息 数 字 芝 未 上 (不 神 1 该 日 期 所 在 月 的 天 数 
w lh 显示 基期 (0 该 日 期 为 一 年 中 的 第 几 天 
D 以 英文 缩写 显示 星期 T 本 地 计算 机 的 时 区 
1 以 英文 全 称 显示 星期 L 判断 是 否 为 疗 年 ,1 表示 是 


【 例 8.39】 显示 时 间 ( 假 设 系统 时 间 为 2016 年 9 月 10 日 10: 10: 00)。 


<?PHP 
Date Default TimeZone Set('PRC'); 
Echo Date("Y -m-d")." <r >"; 
Echo Date ("y -m-d")." <or >"; 
Echo Date ("y 年 m 月 d 日 ")."<br >"; 
Echo Date ("h:i:s") ."<br >"; 
Echo Date ("Y -m-d h:i:s")." dr >"; 
FE 


3. 返回 日 期 时 间 到 数组 中 
函数 格式 : 


GetDate () 


// 输 出 2016 -09 -310 

// 输 出 16 -09 -10 

// 输 出 16 年 09 月 10 日 

// 输 出 10:10:00 

// 输 出 2016 -09 30 10:10:00 


函数 说 明 : 函数 返回 当前 的 日 期 时 间 , 并 将 各 种 时 间 字 有 段 保存 到 接收 数组 变量 中 。 
【 例 8.40】 获取 系统 日 期 时 间 ( 假 设 系统 当前 日 期 时 间 是 2016-10-1 20:20:45)。 


<?PHP 
oday =GetDate () 7 
// 输 出 数组 中 部 分 元 素 的 内 容 


Echo " oday [year] 年 Yoday [mon] 月 人 oday [mday] 日 "; 


// 将 当前 的 时 期 时 间 保 存 到 数组 oday 中 


// 函 数 Print z() 是 用 于 递归 打印 数组 或 对 象 的 语句 ,可 以 将 数组 整体 输出 


Print r( oday); 


/* 显示 结果 : Array ([seconds] =X5 [minutes] = 况 0 [hours] =>20 [mday] =1 
[wday] =X [mon] = 习 0 [year] = 况 016 [yday] = 况 74 [weekday] =>Saturday 
[month] =>October [0] = 习 475324445 ) * / 


可 区 
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// 结 果 : 2016 年 0 月 1 日 


4. 获取 当前 时 间 的 时 间 截 
函数 格式 : 
Time () 


函数 说 明 : Time 函数 返回 当前 时 间 的 时 间 戳 。 
【 例 8.41】 时 间 计 算 ( 假 设 系统 当前 日 期 是 2016-10-1) 。 


<?PHP 
Shewtime -Time() 5 *24* 60* 60; 
Echo "现在 是 : ".Date ("Y 和 和-d") ." br >"; // 现 在 是 : 2016 -10 -01 
Echo "5 天 后 是 : ".Date ("Ym-d", 和 ewtime); //5 天 后 是 : 2016 -10 -06 
9% 


5. 设置 时 间 戳 
函数 格式 : 
MkTime (时 ,分 , 秒 ,月 ,日 ,年 ) 


函数 说 明 : MkTime 函数 返回 参数 描述 时 间 的 时 间 戳 。 

【 例 8.42】 显示 时 间 。 

<?PHP 
Date Default TimeZone Set('PRC'); 
Echo "会 议 时 间 : ".Date ("Ym -d,H:i:s",MkTime (8,30,0,10,12,2016)); 
// 程 序 结果 : 会 议 时 间 : 2016 -10 2，08:30:00 

> 


8.8 ”逻辑 值 表 达 式 


PHP 中 有 好 辑 (布尔 , Boolean ) 类 型 数据 ,常量 true 表示 逻辑 真 ,false 表示 逻辑 假 。 此 
外 ,数值 类 型 也 可 以 用 于 进行 逮 辑 判断 , 非 零 表 示 逻 辑 真 , 零 表 示 逮 辑 假 。 当 用 字符 串 作 
为 逻辑 判断 条 件 时 ,null \ 空 字符 串 ("" ) 或 者 零 字 符 串 ("0" ) 为 逻辑 假 ,其 他 字符 串 都 为 
逻辑 真 。 

运算 结果 为 逻辑 型 的 表达 式 称 为 逻辑 值 表达 式 ,关系 运算 ,逻辑 运算 均 可 构成 逻辑 值 
表达 式 , 通 常用 于 程序 中 条 件 判 断 或 循环 控制 。 


8.8.1 逻辑 运算 符 


逻辑 运算 符 用 来 组 合 旭 辑 运 算 的 结果 ,是 程序 设计 中 一 组 非常 重要 的 运算 符 。PHP 
的 逻辑 运算 符 见 表 8-4。 


第 8 章 PHP 程序 设计 基础 


605 


表 8-4 逻辑 运算 符 














运算 符 说 明 举例 运算 结果 
&& 或 and 逻辑 与 运算 $aand $b $a 和 $b 都 为 真 时 结果 为 真 
1 或 or- 人 逻辑 或 运算 $aor $b $a 或 者 $b 其 中 至 少 有 一 个 为 真 ,结果 为 真 
xor 逻辑 异 或 运算 | $axor $b $a 与 $b 一 真一 假 时 ,结果 为 真 
! 逻辑 非 运 算 1$a $a 为 假 时 ,结果 为 真 











【 例 8.43】 测试 变量 值 的 区 间 。 


<?PHP 


各 刁 07 


If( 和 nm”5 and 和 <0 ) 
Echo "变量 的 值 在 5 -20 之 间 "." <br >"; 


Else 


Echo "变量 的 值 不 在 5 ~20 之 间 " ." br >"; 


8.8.2 比较 运算 符 


比较 运算 符 是 对 变量 或 表达 式 的 结果 进行 大 小 、 真 假 等 比较 ,比较 的 结果 为 True 或 
False。PHP 中 的 比较 运算 符 见 表 8-5。 


























表 8-5 比较 运算 符 
运算 符 说 明 举例 运算 结果 
< 小 于 $a<$b $a 小 于 $b 结果 为 真 
> 来 于 $a> $b $a 大 于 $b 结果 为 真 
<= 小 于 或 等 于 $a<=$b $$ a 小 于 或 等 于 名 b 结果 为 真 
>= 大 于 或 等 于 $a>=$b $a 大 于 或 等 于 $b 结果 为 真 
汪汪 相等 $a= = $b $a 等 于 $b 结果 为 真 
! 不 相等 $al= $b $a 不 等 于 $b 结果 为 真 
当 汪 和 恒 等 $a=== $b $a 恒 等 于 $b 结果 为 真 
l== 非 恒 等 $al== $b $a 非 恒 等 于 $b 结果 为 真 











相等 运算 符 ( = = ) 只 是 对 两 个 变量 的 值 进 行 比较 ,而 恒 等 运 算 符 ( = = = ) 则 对 运算 
符 两 侧 的 表达 式 同 时 进行 值 和 数据 类 型 的 比较 ,只 有 两 侧 的 值 相等 且 数 据 类 型 相同 ,运算 
结果 才 是 逻辑 真 。 


【 例 8.44] 


<?PHP 


比较 运算 符 的 应 用 。 
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站 0 be // 定义 整 型 变量 知 , 实 型 变量 $b, 字 符 串 变量 $c 


if( $a ==$p) // 判断 拓 和 和 是 否 相 等 
echo ' 和 和 和 相等 Zbr >"'; // 显 示 此 行内 容 

if( $a ===$p) // 判断 拓 和 和 是 否 恒 等 
echo ' 和 和 扣 恒 等 or >"'; 

else 
echo ' 和 和 和 不 是 恒 等 or >'; // 显 示 此 行内 容 

if( $a==$c) // 判断 委 和 亿 是 否 相等 
echo' 名 和 包 相 等 or >'; // 显 示 此 行内 容 


?> 

在 PHP 中 使 用 比较 运算 符 比 较 一 个 整数 和 字符 串 时 ,系统 会 自动 将 字符 串 转 换 为 整 
数 之 后 再 进行 数值 比较 。 当 比较 两 个 数字 字符 串 时 , 则 自动 将 两 个 字符 串 转换 为 整数 后 
再 进行 比较 。 若 字符 串 不 是 以 数字 开始 时 ,字符 串 转 换 后 的 值 为 0。 


8.8.3 条件 运算 符 


条 件 运算 符 是 三 元 运算 符 , 即 需要 3 个 操作 数 。 
语法 格式 : 
条 件 表 达 式 ?表达 式 1: 表达 式 2 
条 件 运算 符 的 执行 过 程 是 首先 判断 条 件 表达 式 , 若 结 果 为 True , 则 计算 表达 式 1 并 将 
其 结果 作为 条 件 运 算 的 结果 ; 若 条 件 表 达 式 的 计算 结果 为 False, 则 计算 表达 式 2 并 将 其 
结果 作为 条 件 运算 的 结果 。 
【 例 8.45】 条 件 运算 符 的 应 用 。 
<?PHP 
$=2; PP; // 定义 整 型 变量 委 、 多 
Echo ' 变 量 所 的 绝对 值 是 :… $a 20? $a: -Sa; // 显示 得 的 绝对 值 
Echo' <br 变量 和 的 绝对 值 是 : ,和 2>0? 和 : -So; // 显示 各 的 绝对 值 
$b=$a :0? Sa: -$a; // 实现 数学 运算 人 p=| $a1 
Echo " <br >", i==$p?2' 得 等 于 p':' 知 不 等 于 和 ' 


E 


8.8.4 逻辑 值 郴 数 


好 辑 值 函数 的 返回 值 为 True 或 False。 
1. 检查 文件 或 目录 函数 

函数 格式 : 

File Exists (文件 或 目录 名 ) 
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函数 说 明 : File_Exists 函数 检查 参数 所 给 出 的 文件 或 目录 名 是 否 存在 ,如 果 指 定 的 文 
件 或 目录 名 存在 , 则 返回 True ,否则 返回 False。 
【 例 8.46】 验证 File_Exists 函数 的 功能 。 
<?PHP 
Var Dump (File Exists("D: \\XAMPP \\MYSQL \\DATA\\RCZP")); 
// 若 目 录 D: \XAMPP MYSQL \DATA\RCZP 存 在 , 则 输出 bool (true) ,否则 输出 bool (false) 
Echo Var Dump (File Exists("D: \\XAMPP\\MYSQOL \\DATA\\RCZP \\GWB.FRM") ); 
// 若 文 件 D: \XAMPP \MYSQL \DATA \RCZP \GWB. FRM 存在 , 则 输出 bool (true) ,否则 输出 bool 
(false) 
?> 


2. 检查 目录 函数 
函数 格式 : 
Is_Dir (目录 名 ) 
函数 说 明 : Is_Dir 函数 检查 所 给 出 的 目录 名 是 否 是 存在 ,如 果 存 在 , 则 返回 值 为 
True ,否则 ,返回 值 为 False。 
【 例 8.47】 测试 目录 。 
<?PHP 
$x ="d: \\xampp \\mysql \\data \\rczp"; 
If(Is Dir( $x)) 
Echo " $x 是 文件 目录 !" ."<br >"; 


Else 
Echo " 人 x 不 是 文件 目录 !" ." br >"; 


8.9 ”正则 表达 式 简介 


正则 表达 式 是 一 种 描述 字符 串 结构 模式 的 形式 化 表达 方法 ,是 一 个 高 效 的 文本 处 理 
工具 ,可 以 验证 用 户 输入 的 数据 和 检索 大 量 的 文本 。 在 PHP 中 ,正则 表达 式 应 用 最 好 的 
体现 是 对 表单 提交 的 数据 进行 验证 ,判断 数据 的 合理 、 合 法 性 。 


8.9.1 正则 表达 式 概述 


PHP 中 的 正则 表达 式 是 一 个 模式 字符 串 ,描述 正则 表达 式 以 模式 定 界 符 */ 开始 且 
以 模式 定 界 符 “/” 结 束 , 中 间 可 以 加 入 普通 字符 和 特殊 字符 。 其 中 定 界 符 也 可 以 使 用 除 
数字 .字母 和 和 斜 线 以 外 的 任何 字符 。 正 则 表达 式 作为 一 个 模板 ,可 以 将 设 定 的 字符 模式 与 
所 搜索 的 字符 串 进行 匹配 。 
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1. 普通 字符 


正则 表达 式 中 的 普通 字符 包括 单个 字符 (a ~z,A ~Z,0 ~9) 模式 单元 ( 即 由 多 个 普 
通 字符 组 成 的 原子 ) .普通 字符 表 ( 如 [ABC] ) .普通 转 义 字 符 ( 如 \n 换行 符 、\r 回 车 符 
等 ) 。 正 则 表达 式 中 的 普通 转 义 字符 见 表 8-6。 


表 8-6 正则 表达 式 的 普通 转 义 字符 
























































字符 说 明 
Ne] 位 于 括号 中 的 任意 字符 
[ +] 不 在 括号 中 的 任意 字符 
人 除 换行 符 和 其 他 Unicode 行 终止 符 之 外 的 任意 字符 
\d 匹配 一 个 数字 字符 ,等 价 于 [0-9] 
\D 匹配 一 个 非 数字 字符 ,等 价 于 [ 0-9] 
\w 任何 单词 字符 ,包括 字母 和 下 面 线 , 等 价 于 [ A-Za-z0-9] 
\W 任何 非 单词 字符 ,等 价 于 [ a-zA-Z0-9] 
\s 任何 空白 字符 ,包括 空格 . 制 表 符 、 分 页 符 等 ,等 价 于 [ \f\n\r\t\v] 
\S 任何 非 空白 字符 ,等 价 于 [ \f\vnvrvtvv] 
¥f 分 页 符 , 等 价 于 \x0c 或 者 \cL 
\n 换行 符 ,等 价 于 \x0Aa 或 者 \cJ 
\r 回 车 符 ,等 价 于 \x0d 或 者 \eM 
At 制 表 符 , 等 价 于 \x09 或 者 \cI 
\ 垂直 制 表 符 , 等 价 于 \x0b 或 者 \cK 
\oNN 八进制 数字 ,例如 \o24 
\Xnn 十 六 进 制 数 字 , 例 如 \X2f 
\eC 匹配 一 个 控制 字符 
2. 特殊 字符 
正则 表达 式 中 的 特殊 字符 就 是 一 些 有 特殊 含义 的 字符 ,例如 ,”* "用 来 表示 任何 字 
符 串 ,主要 有 如 下 格式 。 


(1) 原子 表 。 原 子 表 “[ ] "存放 一 组 原子 ,只 需要 匹配 其 中 的 一 个 原子 。 例 如 ,模式 
/m[0123456789 ]/ 表 示 m 字母 开头 其 后 连接 任意 数字 ,一 组 按 ASCII 码 顺序 排列 的 原子 
可 以 使 用 *-" 连 接 , 用 于 简化 书写 ,例如 /m[0123456789 ]/ 可 以 表示 成 /m[0-9]/。 

【 例 8.48】 原子 表 应 用 。 


<?PHP ”//Ereg() 函 数 , 查 看 字符 串 匹 配 情况 ,匹配 成 功 返 回 1, 否 则 返回 False 
Echo Ereg ("A[0123456789]"，"A23A3"); ”// 调 用 Ereg() 函 数 ,显示 匹配 结果 :1 
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Var Dump (Ereg ("A[0 -9]",，"AB233")); ”// 匹 配 不 成 功 ,显示 匹配 结果 : bool (false) 
学 


正则 表达 式 作为 参数 出 现在 Ereg( ) 函数 中 ,其 中 的 定 界 符 可 以 省 略 不 写 (例如 ， 
/A[0-9]/ 写 成 A[0-9])。 

(2) 重复 匹配 。 用 于 重复 匹配 之 前 原子 的 特殊 字符 ,共有 3 种 ,分 别 是 * x* ”+” 和 
“?” ,三 者 实现 功能 相同 ,区 别 是 匹配 的 次 数 不 同 。 其 中 ” * ”表示 重复 匹配 之 前 的 原子 0 
次 1 次 或 多 次 "+ ”表示 重复 匹配 之 前 的 原子 1 次 或 多 次 ,“?" 表 示 匹 配 之 前 的 原子 0 次 
或 1 次 。 

若 要 精确 指定 重复 的 次 数 可 以 使 用 特殊 字符 “| 1" ,其 中 |m| 表示 重复 m 次 ;| my,nl 
表示 重复 匹配 之 前 的 原子 至 少 m 次 ,最 多 nm 次 ; | m, | 表示 重复 匹配 之 前 的 原子 不 少 于 
m 次 。 

【 例 8.49】 正则 表达 式 应 用 。 


<?PHP 
Echo Ereg ("<[a -zA -2Z] [a -zA -20 -9] * >"," php >"); 
/*" <" 开头 ,第 2 位 为 任意 字母 ,之 后 为 任意 多 个 字母 或 数字 ,最 后 " >" 结 尾 ,符合 条 件 的 字 
符 串 则 匹配 成 功 ,结果 输 出 : 1 * / 
Var Dump (Ereg ("de2r", "deer") ); 
//de?r 匹配 dr 或 der, 本 语句 输出 结果 : bool (false) 
Echo Ereg ("go +se", "goose") 7 
//go +se 中 " +" 之 前 的 o 可 以 多 次 出 现 , 故 goose 匹配 ,输出 : 1 
Echo Ereg ("go * d", "good"); // 输 出 结果 : 1 
Echo Ereg ("go{1,2}d", "good"); 
//god、good 都 是 匹配 结果 ,输出 结果 : 1 
?> 


(3) 边界 限制 。 在 正则 表达 式 中 对 匹配 的 范围 进行 限制 ,以 此 来 获取 更 加 准确 的 匹 
配 结果 。 对 匹配 范围 的 边界 限制 有 两 种 方法 : 一 是 确保 模式 的 匹配 字符 从 字符 串 的 左 侧 
开始 ,通过 特殊 字符 ““" 或 “\A”" 实 现 ;二 是 确保 模式 的 匹配 字符 从 字符 串 的 右 端 开始 , 通 
过 特殊 字符 “$” 或 “\Z” 实 现 。 

【 例 8.50】 边界 限制 应 用 。 


<?PHP 
Sasername ="U08"; 
Echo Ereg("^U[0 -9] +%, dsername); // 输 出 结果 : 1 
/* 判断 gsername 中 的 用 户 名 是 否 以 字母 T 开 始 ,以 若干 位 数字 结尾 ,若是 ,函数 结果 为 1， 
否则 为 0* / 





2> 


(4) 特殊 字符 “.”。 用 于 匹配 除 换行 符 以 外 的 任何 一 个 字符 ,相当 于 [“\n] (UNIX 系 
统 ) 或 者 [ ~\r\n] ( Windows 系统 ) 。 
【 例 8.51】 正则 表达 式 匹配 字符 。 
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<?2PHP 
$1 ="hello,world!™"; 
If (Preg Match("/./", $1)){ 
Echo "字符 串 匹 配 成 功 !";} 
Else{ 
Echo "字符 串 匹 配 不 成 功 !";} 
时 
(5) 模式 单元 。 特 殊 字 符 “( ) "将 其 中 的 正则 表达 式 变 为 原子 使 用 ,原子 可 看 作 一 个 
整体 , 称 为 模式 单元 。 使 用 模式 单元 ,其 中 的 表达 式 可 以 被 优先 处 理 。 
(6) 模式 选择 符 。 特 殊 字 符 “1” 为 模式 选择 符 , 其 作用 是 在 正则 表达 式 中 对 匹配 的 
条 件 进 行 选择 ,通常 可 以 匹配 两 个 或 多 个 选择 。 
【 例 8.52】 使 用 正则 表达 式 判 断 固定 电话 号 码 格式 是 否 正确 。 
对 固定 电话 号 码 的 格式 进行 判断 ,可 将 电话 号 码 的 格式 分 为 3 种 : 区 号 3 位 号 码 8 
立 区 号 4 位 号 码 7 位 .区 号 4 位 号 码 8 位 。 其 中 区 号 与 电话 号 码 间 以 *- "分隔 , 则 用 于 判 
断 的 正则 表达 式 为 /[0-9]131-[0-9]181 $1 [0-9]141-[0.9]17,8| $/。 





<?PHP 
多 ="^[0 -9] {3} -[0 -9] {8} $I^[0 -9] {4} -[0 -9] {7,8} $"; 
d="0431 -85168162"; 和 则 =024 -85168162"; 多 "0431 -85155"; 
Var_Dump (Ereg (后 , 锡 )); // 结 果 : int (1) 
Var Dump (Ereg ( 牛 , 多 ));  // 结 果 : int(1) 
Var _ Dump (Ereg ( 牛 , 完 ));  // 结 果 : bool (false) 

?> 


8.9.2 ”正则 表达 式 函数 


1. Preg_Match( ) 函数 
函数 格式 : 
Preg Match (pattern，subject [,matches]) 


函数 说 明 : 字符 串 pattern 指定 匹配 的 正则 表达 式 ,subject 指定 要 搜索 的 字符 串 ,函数 
返回 匹配 的 次 数 ,返回 0 表示 匹配 不 成 功 ,返回 1 表示 匹配 成 功 。 函 数 只 进行 一 次 匹配 。 
给 定 参 数 matches 则 将 比 对 结果 存放 在 matches 数组 中 ,matches[0] 中 的 内 容 就 是 原 字 符 
串 subject,matches[ 1 ] 为 第 一 个 合乎 规则 的 字符 串 , matches[2] 为 第 二 个 合乎 规则 的 字 
符 串 ,以 此 类 推 。 若 省 略 参数 matches , 则 只 进行 比 对 ,找到 则 返回 值 1 。 

Preg_Match( ) 函数 中 的 正则 表达 式 必 须 书写 定 界 符 。 

【 例 8.53】 查找 匹配 的 字符 。 

C2PHP 

Sate Date ("Y m-d"); // 假 设 当 前 日 期 2016.12.27 
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If (Preg Match("/([0 -9]{4}) -([0 -9]{1,2}) -([0 -9]{1,2}))/", $ate, $regs)) { 
Echo " $regs [3] . 人 egs [2]. 人 egs[1]"; // 显 示 结 果 : 27.12.2016 
Print r( Segs);//Array ([0] = 况 016 -12 -27 [1] = 况 016 [2] = 习 2 [3] =>27 ) 
}Else { 
Echo "日 期 格式 错误 : $ate"; 
站 


2> 


2. Ereg( ) 函数 
函数 格式 : 


Ereg (pattern, subject, matches) 


函数 说 明 : 参数 的 意义 同 Preg_Match( ) ,Ereg( ) 函数 的 返回 值 为 数值 ,1 表示 匹配 成 
功 ,0 表示 匹配 失败 , 若 用 布尔 值 表示 结果 , 则 True 为 1 ,False 为 0。Ereg( ) 函数 中 的 正则 
表达 式 可 以 省 略 定 界 符 。 

【 例 8.54】 检查 网 址 是 否 正确 。 

<? PHP 

httpes ="http://www.jlu.edn.cn"; 
$result Freg ("^ (http |ftp) s?:/ (www。) ?. +(com Inet lorg Icn) $%, httpes); 
If( Sesult ==True) 
Echo "输入 的 网 站 格式 正确 !"; 
Else 
Echo "输入 的 网 站 格式 不 正确 !"; 


2> 
正则 表达 式 ( http1ftp)s?:A(www\. )?. + (comlnetlorglcn) $ 确 定 网 址 开始 为 


“https :Awww. "或 “ftps:/www. ”结束 为 com net .org 或 cn ,与 此 格式 不 符合 的 均 判 断 为 
不 正确 。 


3. Preg_Replace( ) 函数 

函数 格式 : 

Preg Replace (pattern, replacement, subject) 

函数 说 明 : Preg_Replace 函数 在 subject 中 搜索 pattern 模式 的 匹配 项 并 替换 为 
replacement。 返回 值 为 替换 后 的 字符 串 ,如 果 没 有 可 以 替换 的 匹配 项 , 则 函数 返回 原始 字 
符 串 。 

replacement 可 以 包含 \$n 形式 的 引用 。 每 个 引用 将 被 替换 为 与 第 n 个 被 捕获 的 括 
号 内 的 子 模式 所 匹配 的 文本 。 如 果 蔡 换 内 容 含 数字 , 则 使 用 \$ | n| 格式 确定 所 引用 的 
序号 。 

【 例 8.55】 正则 表达 式 的 内 容 替 换 。 
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<2PHP 


$1 —"October 1,2016"; 
P23/(WH) (hd 和 /An // 三 项 分 别 对 应 \, \ 多 ,\33 
G3="\9 18, \%"; // 替 换 后 的 内 容 变 为 \9 18,\ 久 
4="\H1}18, \8"; 


Echo Preg Replace ( 多 2, 和 3, 鲍 1); ”// 得 到 结果 : October 18,2016 
Echo Preg Replace ( 2, $ 4,， $1); ”// 得 到 结果 : October18,2016 


> 


4. Split( ) 函数 
函数 格式 : 
Split (pattern, str[, limit]) 
函数 说 明 : 使 用 正则 表达 式 将 字符 串 分 割 到 数组 中 。 函 数 返回 一 个 字符 串 数组 ,每 
个 单元 为 str 经 正则 表达 式 pattern 分 割 出 的 子 串 ,失败 则 返回 False。 其 中 pattern 指定 分 
割 使 用 的 正则 表达 式 ,str 指定 要 操作 的 字符 串 ,limit 指定 返回 数组 单元 的 个 数 ,如 果 指 定 
参数 limit, 则 返回 的 数组 中 最 多 包含 limit 个 单元 ,而 其 中 最 后 一 个 单元 存储 参数 str 中 琵 
余 的 所 有 部 分 。 

【 例 8.56】 拆 分 字符 串 。 





<?PHP 

Samail ="tsaocao@163 .com"; 

drray -Split ("\. l@", Pmail); // 拆 分 字符 串 email 

While (List ( key, Walue) Fach ( Grray)) { 

Echo " ey, Walue <r >»>";} // 结 果 : 0,tsaocao 1,163 2, com 
?2> 


List( ) 函数 用 数组 中 的 元 素 为 一 组 变量 赋值 。Each( ) 函数 生成 一 个 由 数组 当前 内 部 
指针 所 指向 的 元 素 的 键 名 和 键 值 组 成 的 数组 ,并 把 内 部 指针 向 前 移动 。 


习 题 


一 、 填空 题 

1. 使 用 Dreamweaver 开发 PHP 应 用 程序 , 单 击 “ 文 件 " 菜 单 四 选项 ,在 四 
对 话 框 中 选择 “文档 类 型 "为 ”_@) _, 单 击 “ 创 建 "按钮 即 可 。 

2. 在 Dreamweaver 中 编写 PHP 应 用 程序 时 ,在 “中 ” 窗 格 中 输入 PHP 程序 ,要 查看 
程序 的 运行 效果 ,可 以 单 击 ”选项 或 _@ 选项 。 

3. PHP 中 的 变量 用 _Q@ 开头 ,可 以 接任 意 多 个 @@ 、@  、@ 和 人 @， 
但 连接 的 第 一 个 符号 不 能 是 _@ ,变量 名 区 分 大 小 写 。 
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4. PHP 标记 能 够 让 _ 中 ”识别 PHP 代码 的 开始 和 结束 。 标 准 风格 的 PHP 开始 标记 
是 _@ ,简短 风格 的 开始 标记 是 ”@@”,ASP 风格 的 开始 标记 是 ”@ ,标准 风格 和 简 
短 风格 的 结束 标记 是 ”@”,ASP 风格 的 结束 标记 是 @ 。 

5. PHP 语句 必须 以 _Q@ 结尾 ,代码 中 的 _@@ 、@@ 和 @ 不 区 分 大 小 写 , 命 
令 .短语 和 函数 名 中 英文 字母 .专用 符号 一 律 以 _@) 方式 输入 。 

6. 注释 即 代 码 的 解释 和 说 明 ,通常 放 在 代码 的 _Q@D 或 @@ 。 注释 有 3 种 风格 ,C 
风格 注释 以 _@ 开始 ,以 国 结束 ;C++ 风格 注释 以 _ 回 开始 ;Shell 风格 注释 以 

@ 开始 。 
7. 表达 式 是 构成 PHP 程序 语言 的 基本 元 素 ,通常 表达 式 中 可 以 出 现 四、 
@ 、®@ @、、@ 和 @ 等 。 

8. 字符 串 是 由 0 或 多 个 字符 构成 的 一 个 集合 ,在 PHP 中 有 3 种 定义 字符 串 的 方式 ， 
分 别 是 中 、@ 和 国 ， 四 表示 的 字符 串 可 以 包含 变量 名 ,并 且 变 量 名 自动 
替换 成 变量 的 值 ， 中 ”表示 的 字符 串 则 将 变量 名 当成 普通 字符 。 

9. 连接 字符 串 使 用 “运算 符 , 用 于 将 两 个 字符 串 连接 成 一 个 新 的 字符 串 。 

10. 去 掉 字 符 串 前 后 的 空格 用 _ 四 、@ 或 @ 函数 ;计算 字符 串 长 度 用 
_@ 函数 ,在 UTF-8 字符 集中 ,每 个 汉字 长 度 为 “@ ;比较 字符 串 用 _@ 函数 ,其 
返回 值 为 _@ 时 表示 比较 的 两 个 字符 串 相 等 。 

11. 在 PHP 中 ,八进制 整 型 常量 需要 在 数值 前 加 _Q@ _, 十 六 进 制 整 型 常量 需要 在 
数值 前 加 ”多 ”。 浮 点 型 常量 的 表示 一 种 是 _@)_, 另 一 种 是 采用 @ 格式 。 

12. 在 PHP 中 ,计算 绝对 值 使 用 QD 函数 ,对 数值 进行 四 舍 五 入 操作 使 用 @ 
函数 ,开平 方 使 用 _@_ 函数 ,计算 3 的 4 次 方 使 用 _@ 函数 。 

13. 在 PHP 中 ,获取 当前 系统 的 日 期 时 间 使 用 _Q@ 函数 ,将 字符 串 2017-10-7 
10:10:20 转换 为 UNIX 时 间 截 使 用 _@ ”函数 ,设置 系统 当前 时 区 使 用 _@ 也 数 ,将 时 
区 设 为 北京 时 区 使 用 参数 _@ 。 

14. 在 PHP 中 书写 表达 式 时 ,要 使 两 个 条 件 同 时 成 立 应 该 使 用 _Q(D 运算 符 ;给 定 
的 两 个 条 件 满足 其 中 一 个 即 可 , 则 应 该 用 _@@ ”运算 符 连 接 ; 给 定 的 两 个 条 件 只 能 满足 一 
个 时 应 该 用 _@ ”运算 符 连 接 ;给 定 的 条 件 不 成 立时 执行 操作 , 则 应 该 用 _@ 运算 符 
处 理 。 

15. 正则 表达 式 是 一 种 描述 _Q@D_ 结构 模式 的 形式 化 表达 方法 ,是 一 个 高 效 的 文本 
处 理工 具 , 可 以 验证 用 户 输入 的 数据 和 检索 大 量 的 文本 。 以 ”@@ ”开始 且 以 模式 定 界 符 

@_ 结束 ,中 间 可 以 加 入 _@@_ 和 _ 四。 正则 表达 式 作为 一 个 模板 ,可 以 将 某 个 字符 
模式 与 所 搜索 的 字符 串 进行 @ 。 

16. 正则 表达 式 中 的 普通 字符 包括 四 、 回 、@ 及 四 .正则 表达 式 中 
的 特殊 字符 就 是 一 些 有 特殊 含义 的 字符 ,主要 有 @ 、@ 、@ 、 、@ 
和 @。 


二 、 单 选 题 
1. 在 Dreamweaver 设计 环境 中 ,能 够 书写 PHP 源 程 序 的 视图 是 ( js 
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A. 实时 视图 B. 代码 视图 C. 程序 视图 D. Web 视图 
2. 在 Dreamweaver 设计 环境 中 ,能 够 查看 PHP 源 程序 执行 效果 的 视图 是 ( We 


A. 实时 视图 B. 代码 视图 C. 效果 视图 D. 浏览 器 视图 
3. 在 PHP 中 命名 变量 名 不 能 使 用 的 符号 是 ( je 

A. 字母 B. 数字 人 D. 下 面 线 
4. 下 列 PHP 变量 名 命名 错误 的 是 ( ) 

A. $name B. $fid GC 鲁 寺 A D. $m7_ 
5. 标准 风格 的 PHP 标记 以 ( ) 开 始 ,以 “? > "结束 。 

A. <? B. <? php C. <html D。 <icp 


6. 在 PHP 中 ,命令 短语、 函数 名 中 的 英文 字母 专用 符号 (如 各 种 运算 符 . 单 引号 、 
双 引 号 、 圆 括号 等 ) 一 律 以 (  ) 输 入 。 


A. 大 写 方 式 B. 小 写 方式 C. 全 角 方式 D. 半角 方式 
7. PHP 语句 必须 以 ( ) 结 尾 , 一 行 可 以 输入 多 条 语句 。 
A. 分 号 B. 句号 C. 顿 号 D. 减 号 
8. 有 变量 定义 $b = -5; 则 语句 Echo " $b 为 负数 " ;的 结果 是 ( 。 )。 
A. " 书 b 为 负数 " ”B. $b 为 负数 C. 为 负数 D.， -5 为 负数 
9. 语句 “Echo 'hello'. 123; "的 输出 结果 是 ( je 
A. hello B: 123 C. hello123 D. 123hello 
10. 在 UTF-8 字符 集中 ,语句 “Echo Sulen ("招聘 成 绩 合格 " ) ; ”的 输出 结果 是 
( ) 。 
A. 6 B. 12 CG: 18 D. 24 


11. 在 PHP 中 有 变量 定义 $a =" 吉 林 大 学 大 学 城 " ,用 UTF-8 字符 集 ,从 变量 $a 中 
提取 字符 串 “ 吉 林 大 学 " 存 人 变量 $b, 可 以 使 用 的 语句 是 ( js 


A. $b=Left( $a,12) B. $b=Substr( $a,0,12) 
C. $b=Ltrim( $a) D. $b=Rtrim( $a) 
12. 在 PHP 中 有 变量 定义 $a = 10; 执 行 赋值 操作 $b = + + $a 后 ,$b 的 值 
为 ( ) 。 
A. 10 B. 11 G 到 D. 0 


13. 在 PHP 中 有 变量 定义 $a = 123. 45689 ,要 将 $a 变量 保留 小 数 点 后 3 位 的 结果 
存 人 变量 $b, 应 该 执行 的 操作 是 ( )。 


A. $b=Right( $a,3) B. $b=Substr( $a,3) 
C. $b=Abs( $a,3) D. $b=Round( $a,3) 
14. 在 PHP 中 ,要 实现 计算 2" 的 值 ,可 以 使 用 函数 ( 上 
A. Round(2,10) B. Sqrt(2,10) C. Logl0(2) D. Pow(2,10) 


15. 在 PHP 中 ,有 变量 定义 $a ="2017-11-09 20:28:00", 则 调用 函数 Strtotime 
( $$ a) ,函数 的 返回 值 类 型 是 ( je 
A. int B. float C. date D. datetime 
16.“ $a 是 小 于 10 的 非 负 数 ” ,在 PHP 中 用 表达 式 表示 为 ( )。 
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A.0<=$a<10 B.0<= $aAnd $a<10 


C.0<= $aOr $a<10 D. 0<= $aXor $a<10 
17. 在 PHP 中 ,与 表达 式 “! ($a< =0 Or $a> =10)” 等 价 的 表达 式 是 ( )。 
A. $a<0 And $a>10 B. $a>0 Or $a<10 
C. $a>0 And $a<10 D. 0<$a<10 
18. 在 PHP 中 ,有 变量 定义 “$a=123; $b =1.23e2;”, 则 表达 式 “ $a= = $b" 的 结 
果 是 ( a 
A. 123 B. 1.23e2 C. True D. False 
19. 在 PHP 中 ,判断 文件 是 否 存在 的 函数 是 ( js 
A. File() B. If_File() C. Is_Dir() D. File_Exists( ) 
20. 下 列 ( ) 不 是 正则 表达 式 中 的 普通 转 义 字符 。 
A. \n B. \d C. \t D. \m 
三 、 多 选 题 
1. 下 列 软件 能 够 编辑 ,调试 PHP 程序 的 有 ( js 
A. Dreamweaver B. PHPCoder C. Eclipse D. PSPad 


E. Notepad ++ 
2. 注释 即 代码 的 解释 和 说 明 ,通常 放 在 代码 的 ( ) 。 


A. 上 方 B. 中 间 C. 尾部 D. 脚注 
E. 尾 注 F. 标注 
3. PHP 中 支持 的 注释 风格 有 ( js 
A. C++ 风 格 B，Turing 风格 C. Shell 风格 D. HTML 风格 
E. C 风格 


4. filel. php 中 包含 若干 个 PHP 函数 ,在 其 他 PHP 程序 中 调用 这 些 函 数 之 前 ,要 用 
(  ) 函 数 说明 flel. php。 
A. Include B. Require_once C. Require D. Contain 
E. Include_once F. Embody 
5. 在 PHP 中 有 多 种 定义 字符 串 的 方式 ,分 别 是 (。”)。 
A. 分 号 B. 双 引 号 C. 标注 符号 D. 单 引号 
E. 界定 符 F. 方 括号 
6. 在 PHP 中 有 变量 定义 $a= "招聘 人 才 信 息 库 " ,要 将 变量 $a 的 前 后 空格 清除 ,可 
以 使 用 的 操作 有 (  ” ) 。 


A. Trim( $a) B. $a=Trim( $a) 

C. $a=Ltrim( $a) D. $a=Ririm( $a) 

E. $a=Ltrim(Rtrim( $a)) F. $a=Rtrim(Ltrim( $a)) 
7. 下 列 数 据 表示 中 属于 浮 点 数据 类 型 的 是 ( )。 

A. 1233.898 B. Ox78f C. 123.3e+4 D. 0335 

E. 12890 


8. 在 PHP 中 , 整 型 数值 可 以 使 用 的 进位 制 有 ( ) 。 
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A. 二 进 制 B. 八进制 C. 十 进 制 D. 十 六 进 制 
E. 任意 R 进 制 





. 在 PHP 程序 中 ,能 够 获取 时 间 戳 的 函数 有 ( )。 


A. Strtotime( ) B. MkTime( ) C. Date() D. DateTime( ) 
E. Time( ) 
在 PHP 程序 中 ,设置 招聘 条 件 为 资格 审核 通过 且 笔 试 面试 成 绩 均 合 格 , 则 下 列 


表达 式 正确 的 是 (。” )。 


符 ( 


有 ( 


~ 人 小 上 wm 一 


A. 资格 审核 or 笔试 成 绩 > =60 or 面试 成 绩 > =60 
B. 资格 审核 and 笔试 成 绩 > =60 and 面试 成 绩 > =60 
C. 资格 审核 and 笔试 成 绩 > =60 or 面试 成 绩 > =60 
D. 资格 审核 && 笔试 成 绩 > =60 && 面试 成 绩 > =60 
E. 资格 审核 and 笔试 成 绩 > =60 && 面试 成 绩 > =60 
F. 资格 审核 or 笔试 成 绩 > =60 and 面试 成 绩 > =60 


. 下 列 属 于 正则 表达 式 中 普通 转 义 字符 的 是 ( ”)。 


A. \m B. \n CG Wt D. \d 
E. \b F. \S 
. 在 PHP 正则 表达 式 中 ,下 列 字符 串 匹 配 模式 a(bc)10,21d 的 有 (  ”)。 
Py B: vad" C. "abcd" D. "abcbed" 
E. "ab02d" F. "abd02" 
. 在 PHP 正则 表达 式 中 , 设 定 模式 的 匹配 字符 从 字符 串 的 左 侧 开始 ,通过 特殊 字 
) 实 现 。 
A.“ B. & C. % D. \A 
E. \Z F. \n 
. 在 PHP 正则 表达 式 中 ,查看 给 定 字 符 串 与 设 定 模式 是 否 匹 配 , 可 以 使 用 的 函数 
) 。 
A. Split( ) B. Ereg() 
C. List(') D. Preg_Replace( ) 
E. Preg_Match() F. Each() 
思 考 题 


. PHP 中 如 何 命 名 变量 ? 怎样 确定 变量 的 数据 类 型 ? 

. PHP 中 有 哪些 数据 类 型 ? 每 种 数据 类 型 的 数据 如 何 表示 ? 

. PHP 中 可 以 用 几 种 方式 定义 字符 串 ? 各 种 方式 之 间 存 在 着 哪些 差异 ? 

. PHP 中 有 日 期 类 型 的 数据 吗 ? 怎样 显示 一 个 具体 的 日 期 时 间 内 容 ? 

. PHP 中 有 哪些 逻辑 运算 符 ? 有 哪些 关系 运算 符 ? 优先 级 如 何 ? 

. PHP 中 正则 表达 式 如 何 定义 ? 使 用 正则 表达 式 主要 是 解决 哪些 问题 ? 

. PHP 的 正则 表达 式 中 ,特殊 字符 都 有 哪些 格式 ? 每 种 格式 的 意义 是 什么 ? 
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PHP 程序 设计 


PHP 程序 是 完成 一 定 任务 的 一 组 有 序 语 句 的 集合 ,也 称 脚本 。PHP 是 结构 化 程序 设 
计 语 言 ,程序 有 顺序 .分支 (选择 ) 和 循环 (重复 )3 种 控制 结构 。 

在 计算 机 处 理 各 种 问题 时 主要 需要 解决 两 个 方面 的 问题 : 第 一 是 数据 在 计算 机 中 的 
存储 问题 ;第 二 是 解决 问题 的 算法 (程序 ) 问题 , 即 计算 机 在 解决 各 种 问题 的 过 程 中 如 何 
对 各 种 问题 做 出 相应 的 迎 辑 判断 并 执行 正确 的 步骤 ,如 何 利用 计算 机 的 高 速 性 来 解决 烦 
琐 上 且 重 复 度 较 高 的 任务 。PHP 程序 设计 主要 解决 下 面 几 个 问题 : 

(1) 如 何 将 一 组 关联 的 数据 作为 一 个 整体 来 统一 定义 与 使 用 ? 

(2) 如 何 利用 PHP 语言 实现 分 支 与 循环 结构 程序 设计 ? 

(3) 如 何 定义 并 使 用 函数 实现 程序 设计 的 模块 化 ? 

(4) 如 何 获取 页 面 数据 ,实现 人 机 交互 ? 

(5) 如 何 对 PHP 程序 的 错误 进行 处 理 ? 





9.1 数 组 


变量 只 能 存储 如 数值 .字符 串 或 日 期 .时 间 等 类 型 的 单一 数据 ,常用 于 存储 完成 简单 
任务 的 临时 数据 。 对 于 某 些 较 复 杂 的 问题 ,如 存储 100 个 应 聘 人 员 的 姓名 及 笔试 成 绩 , 除 
存储 数据 外 ,还 要 表达 数据 之 间 的 关系 。 如 果 定 义 200 个 变量 ,显然 过 于 烦琐 , 且 无 法 反 
映 出 数据 间 的 关联 。 针 对 这 种 问题 ,可 以 用 数组 存储 数据 。 

数组 是 内 存 中 存储 一 组 数据 的 表格 , 即 ,名称 相同 而 下 标 不 同 的 一 组 变量 。 数 组 中 的 
每 个 变量 (单元 ) 被 称 为 一 个 数组 元 素 。 

在 PHP 中 ,允许 一 个 数组 包含 不 同类 型 的 元 素 ,元 素 可 以 是 数值 .字符 串 或 日 期 \ 时 
间 等 简单 类 型 的 数据 ,也 可 以 是 另外 一 个 数组 。 将 仅 包含 简单 类 型 元 素 的 数组 称 为 一 维 
数组 ( 视 为 一 行 或 一 列 元 素 ) ; 将 某 些 元 素 又 为 数组 的 数组 称 为 多 维 数组 。 例 如 ,一 维 数 
组 中 的 元 素 又 是 一 维 数组 , 则 为 二 维 数组 ,以 此 类 推 。 


9.1.1 数组 分 类 


通常 将 数组 元 素 的 编号 称 为 元 素 下 标 , 用 数组 名 及 元 素 下 标 对 数组 中 的 元 素 进行 赋 


值 或 引用 。 根 据 元 素 下 标的 数据 类 型 ,PHP 将 数值 型 下 标的 数组 称 为 索引 数组 ;将 字符 
串 型 下 标 ( 即 与 名 称 关 联 ) 的 数组 称 为 关联 数组 。 


1. 索引 数组 
索引 数组 用 整 型 数 作为 下 标 ,系统 默认 下 标 从 0 开始 ,依次 递增 1。 实 际 应 用 中 ,下 


标 可 以 不 连续 ,也 可 以 不 从 0 开始 排列 ,例如 2.4.6 和 8 等 。 当 需要 通过 相对 位 置 确定 数 
组 元 素 时 ,通常 使 用 索引 数组 。 表 9-1 中 是 一 个 索引 数组 的 示例 。 
表 9-1 索引 数组 的 示例 
数组 元 素 $myarr[0] $ myarr[ 1] $ myarr[2] $ myar[ 3] $ myarr[ 4] 
元 素 值 3 5 7 9 11 





表 中 是 一 个 索引 数组 $ myarr, 共 包含 5 个 元 素 ,元 素 的 值 分 别 是 3.5.7.9 和 11。 通 
过 下 标 表示 数组 中 的 每 个 元 素 , 例 如 , $ myarr[ 1] 表 示 数 组 中 的 第 二 个 元 素 ,当前 值 是 5。 
要 表示 数组 中 的 元 素 , 需 要 使 用 数组 名 和 半角 方 括号 ([ ] ) 及 下 标 。 
2. 关联 数组 
在 关联 数组 中 ,元素 下 标 为 字符 串 ,通常 用 有 意义 的 名 称 命名 ,由 半角 单 引号 或 双 引 
号 将 其 引起 来 。 表 9-2 是 一 个 关联 数组 的 示例 。 
表 9-2 关联 数组 的 示例 





数组 元 素 $zw[ "经 理 " ] $zw[ "助理 " ] $zw[ "主管 "] 





元 素 值 张 亮 王 洋 赵 海 
关联 数组 $ zw 共 包含 3 个 元 素 , 值 分 别 为 张 亮 . 王 洋 和 赵 海 ,要 显示 下 标 为 "助理 "的 
数组 元 素 ,执行 Echo $ zw[ "助理 " ] 语 句 , 则 显示 : 王 洋 。 
9.1.2 创建 数组 


可 以 通过 函数 预先 创建 数组 ,也 可 以 直接 为 数组 元 素 赋值 实现 创建 或 扩充 数组 。 
1. Array( ) 函数 创建 数组 

函数 格式 : 

Rrray([ 下 标 1 = 习 元 素 值 1，[ 下 标 2 = 习 元 素 值 2……) 


函数 返回 值 是 一 个 新 创建 的 数组 。 调 用 函数 时 ,如 果 省 略 下 标 , 则 自动 产生 下 标 从 0 
开始 的 索引 数组 ,数组 中 各 个 元 素 的 数据 类 型 可 以 不 同 ,还 可 以 是 数组 。 当 数组 元 素 本 身 
是 数组 时 ,就 是 定义 了 一 个 多 维 数组 。 

【 例 9.1】 利用 Array( ) 函数 定义 一 个 下 标 从 1 开始 的 索引 数组 ,并 输出 各 个 元 素 。 
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<2?PHP 
SNewarr Array (1 = 泌 网 "2 => 冯 页",3=2 设 "4= 关 计 ”) > 
Print r( SNewarr); ?> 


其 中 Print_r( ) 是 输出 数组 结构 的 函数 ,运行 程序 时 浏览 器 中 显示 的 结果 为 : 
Array ( [1] = 疯 [2] = 项 [3] = 闪 [4] = 六 ) 
【 例 9.2】 利用 Array( ) 函数 定义 一 个 下 标 从 0 开始 的 索引 数组 。 


<?PHP SNewarTray Array ("PHP", "Dreamweaver", "MySQL"); 
Print r( SNewarray); ?> 
运行 程序 后 ,浏览 器 中 显示 的 结果 为 : 
Array ( [0] =>PHP [1] =>Dreamweaver [2] =>ySQL) 
在 前 面 两 个 例子 中 所 创建 的 数组 均 为 索引 数组 。 例 9. 1 中 ,在 创建 数组 时 指定 了 数 
组 元 素 的 下 标 , 且 下 标 可 以 是 任意 数 ,而 在 例 9. 2 中 创建 数组 时 ,没有 为 元 素 指定 下 标 ,其 
数组 元 素 下 标 自 动 从 0 开始 ,依次 增加 1。 
在 创建 关联 数组 时 ,需要 给 出 相应 的 下 标 ,创建 关联 数组 后 ,通过 相应 的 下 标 可 以 直 
接 访问 相应 的 数组 元 素 。 
【 例 9.3】 定义 一 个 关联 索引 数组 ,存储 应 聘 者 考试 成 绩 ,在 文本 框 中 输入 应 聘 者 姓 
名 , 单 击 * 提 交 ” 按钮 将 输出 应 聘 者 成 绩 。 
<Form Action ="" Method ="post" > 
姓名 : <Input Name ="xm" Type "text" /> 
<Input Type ="submit" Name ="button" Value =" 提 交 " / ></Fom> 
<?PHP If (Isset ($ POST["button"])) ”// 用 户 是 否 单 击 "提交 "按钮 
{ $a=$ POST["xm"]; 
$score =array () ; $score[" 刘 德 厚 "] =80; 
$score[" 王 丽 敏 "] 95; $score[" 李 丽 丽 "] 377; 
Echo $score[ $a]; } ?> 
运行 程序 时 ,如 果 在 文本 框 中 输入 王 丽 敏 ,并 单 击 “ 提 交 ” 按 钮 , 则 输出 结果 为 :95 。 
从 上 面 例子 可 以 看 出 ,通过 下 标 直 接 访 问 数据 元 素 ,有 时 会 更 加 方便 快捷 。 


2. 字符 串 转换 为 索引 数组 
函数 格式 : 
Explode (分 隔 符 , 字符 串 [, 元 素 个 数 ]) 


函数 返回 值 是 根据 字符 串 中 的 子 串 创 建 的 .下 标 从 0 开始 的 索引 数组 。 其 中 分 隔 符 
参数 是 字符 串 中 各 个 子 串 之 间 的 分 隔 符 号 ,分 隔 符号 为 空 字符 串 ("" ) 时 ,函数 不 能 创建 
数组 ,而 返回 False。 

参数 元 素 个 数 用 于 说 明 转 换 结 果 的 数组 中 所 含 元 素 的 个 数 ,如 果 省 略 此 项 或 元 素 个 
数 多 于 子 串 个 数 , 则 数组 中 元 素 个 数 与 字符 串 中 子 串 个 数 一 致 ;如 果 元 素 个 数 少 于 子 串 个 
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数 , 则 最 后 一 个 元 素 将 包含 剩余 的 全 部 子 串 。 
【 例 9.4】 依据 字符 串 “ 刘 德 厚 ; 王 丽 敏 ; 李 丽 丽 ; 张 娜 " 生 成 数组 $ xm。 


<?PHP Sm 也 xplode (";"," 刘 德 厚 ; 王 丽 敏 ; 李 丽 丽 ; 张 娜 ") ; 
Print r( $xm); 
Echo "元 素 个 数 : ",Count ( $m) ," <br >"; ?> 


其 中 count( ) 为 返回 数组 中 元 素 个 数 的 函数 。 运 行程 序 输出 的 结果 为 : 
Brray ( [0] = 浏 | 德 厚 [1] = 壮丽 敏 [2] =x 李 丽 丽 [3] = 涨 娜 ) 元 素 个 数 : 4 





3. 赋值 创建 与 扩充 数组 元 素 
在 PHP 中 另 一 种 比较 灵活 的 创建 和 扩充 数组 的 方法 是 直接 为 数组 元 素 赋值 。 如 果 
在 创建 数组 时 不 知道 数组 的 大 小 ,或 者 在 运行 时 数组 的 大 小 发 生 改 变 ,采用 这 种 方法 创建 
数组 比较 好 。 
【 例 9.5】 利用 直接 赋值 的 方法 ,创建 和 扩充 记录 应 聘 者 信息 的 数组 yp。 
<?PHP ”$yp[" 证 件 号 "] ="229901199503121538"; ”// 开始 创建 数组 yp 
$yp[" 姓 名 "] =" 刘 德 厚 "; $yp[" 岗 位 "] =" 行 长 助理 "; $yp[" 笔 试 成 绩 "] =80; 
Echo Count ( $yp), " 个 元 素 "," zbr >"; ”// 输出 : 4 个 元 素 
$yp[" 岗 位 "] = 理财 师 " ; // 修改 元 素 的 值 
$yp[" 面 试 成 绩 "] -90; // 扩充 数组 元 素 
S$yp[" 总 分 "] =$yp[" 笔 试 成 绩 "] * 0.7 +Syp [" 面 试 成 绩 "] * 0.30 
// 在 表达 数 中 引用 2 个 数组 元 素 ,$yp[" 总 分 "] 的 值 为 83 
Echo Count ( Syp)," 个 元 素 "," <zbr >"; ”// 输出 : 6 个 元 素 ?> 
在 上 面 例子 中 ,通过 直接 为 数组 $yp 的 元 素 赋值 创建 了 数组 $yp ,并 且 在 数组 使 用 
的 过 程 中 ,可 以 随时 为 数组 添加 新 的 元 素 。 


9.1.3 输出 数组 


1. 数组 元 素 连 接 成 字符 串 

函数 格式 : 

Implode (连接 符 , 数 组 名 ) 

函数 返回 值 是 将 数组 元 素 用 连接 符 连 接 成 的 一 个 新 字符 串 。 其 中 参数 连接 符 是 字符 


串 型 数据 ,可 以 是 多 个 字符 。 
【 例 9.6】 输出 由 “117 连 接 例 9.5 中 的 $yp 数组 元 素 生 成 的 字符 串 。 


<?PHP 
Echo Implode ("I", Syp); ”// 输出 : 229901199503121538 | 刘 德 厚 ll 理财 师 180 ll90 ll83 ?> 
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2. 输出 数组 

函数 格式 : 

Print r( < 表达 式 

函数 返回 值 为 逻辑 型 数据 。 如 果 表 达 式 参数 是 普通 表达 式 , 则 输出 表达 式 的 值 ;如 果 
表达 式 参 数 是 数组 名 , 则 依次 输出 数组 中 的 所 有 元 素 ( 参 考 例 9.4 的 程序 输出 的 结果 ) 。 

Print_r 与 Echo 都 可 以 输出 表达 式 的 值 。 二 者 的 主要 区 别 在 于 : 

(1) 书写 格式 : Echo 通常 作为 语句 使 用 ,可 以 输出 多 个 表达 式 的 值 ( 不 能 加 小 括 
号 ) , 仅 输出 一 个 表达 式 的 值 时 ,可 以 加 小 括号 。 例 如 ,Echo( $ yp[ "笔试 成 绩 " ] * 0.7) ; 
Print_r 必须 加 小 括号 ,并且 只 能 有 一 个 参数 。 

(2) 返回 值 : Echo 没有 返回 值 , 因 此 不 能 写 在 表达 式 中 ; Print_r 的 返回 值 为 逻辑 型 ， 
可 以 作为 表达 式 中 的 一 个 运算 项 。 

(3) 输出 对 象 : Echo 只 能 输出 表达 式 的 值 ,不 能 输出 整个 数组 ;Print_r 可 以 输出 一 个 
表达 式 的 值 或 数组 ,一 般 用 于 输出 数组 中 的 所 有 元 素 。 例 如 , 例 9.4 中 的 Print_r( $xm) 。 


3. 数组 元 素 的 引用 


在 设计 程序 时 , 像 变 量 一 样 引用 数组 元 素 ,引用 格式 为 : 数组 名 [下 标 ]。 例 如 ,在 例 
9.5 中 ,$yp[" 姓 名" ] =" 刘 德 厚 " 和 $yp[" 岗 位"] =" 行 长 助理 "等 语句 均 是 为 数组 元 
素 赋 值 ;在 表达 式 $ yp[ "笔试 成 绩 " ] * 0.7 + $yp[ "面试 成 绩 " ] * 0. 30 中 ,引用 了 $yp 
[" 笔 试 成 绩 " ] 和 $yp[ "面试 成 绩 " ] 两 个 数组 元 素 。 


9.1.4 多 维 数组 


假定 有 一 个 数组 A, 其 中 元 素 仍然 为 数组 ,那么 数组 A 就 构成 了 多 维 数组 。 一 个 一 维 
数组 ( 视 为 一 行 或 一 列 的 表格 ) 的 元 素 如 果 仍 为 一 维 数组 ,那么 它 被 称 为 二 维 数组 (多 行 
和 多 列 的 二 维 表格 ) ;如 果 二 维 数组 中 的 元 素 仍 为 一 维 数组 ,就 构成 了 三 维 数组 ;以 此 类 
推 ,可 以 构建 出 四 维 .五 维 数组 等 。 通 常 可 以 将 二 维 数组 理解 为 一 个 矩阵 或 者 一 个 二 维 表 
格 。 表 9-3 是 记录 应 聘 者 信息 的 二 维 表格 。 


表 9-3 应聘 者 信息 的 二 维 数组 




















身份 证 号 姓名 成 绩 
229901199503121538 刘 德 厚 80 
11980119921001132X 王 丽 敏 95 
229901199305011524 李 丽 丽 77 


【 例 9.7】 用 表 9-3 的 数据 创建 二 维 数组 。 
<?PHP $info Array (Array ("229901199503121538", " 刘 德 厚 ",80) ， 
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Rrray("11980119921001132X ", " 王 丽 敏 ", 95), Array ("229901199305011524"," 李 丽 丽 "， 
77)); 
Print r($info); ?> 


程序 运行 结果 如 下 : 
Array ([0] =>array ([0] = 总 29901199503121538 [1] = 济 | 德 厚 [2] =>80) 


[1] =>array ([0] = 习 1980119921001132X [1] = 汪 丽 敏 [2] =>95) 
[2] =>array ([0] = 况 29901199305011524 [1] = 疮 丽 丽 [2] =377)) 


下 列 代码 与 例 9.7 的 程序 等 效 : 


<?PHP $info[0] rray ("229901199503121538", " 刘 德 厚 ",80) ; 
Sinfo[1] rray ("11980119921001132X ", " 王 丽 敏 ",95); 
Sinfo[2] rray ("229901199305011524", " 李 丽 丽 ",77); 
Print r($info); ?> 


对 二 维 数组 元 素 赋值 或 引用 时 ,元 素 格式 为 : 数组 名 [ 行 下 标 ][ 列 下 标 ] 。 
【 例 9.8】 创建 存储 姓名 和 成 绩 的 二 维 数组 ,并 输出 相关 元 素 的 值 。 
<?PHP ”scj [1] [1] =" 刘 德 厚 "; sj [1] [2] =80; ”// 创建 数组 并 为 元 素 赋值 
$cj [2] [1] =" 王 丽 敏 "; ”$cj [2] [2] =95; $cj [3] [1] ~" 李 丽 丽 "; $cj [3] [2] 377; 


Echo $cj[1] [1]," or >", $cj [2] [1]," br>", $cj[3][2]; 
// 在 表达 式 中 引用 二 维 数组 元 素 ,输出 3 行 数据 依次 为 : 刘 德 厚 王 丽 敏 和 77 ?> 


9.2 分 支 程序 设计 


分 支 结构 是 流程 控制 的 重要 手段 之 一 ,又 称 为 选择 结构 或 条 件 结构 ,分支 结 构 的 执行 
是 依据 一 定 的 条 件 选择 执行 路 径 ,而 不 是 严格 按照 语句 出 现 的 顺序 。 分 支 结构 程序 设计 
的 关键 在 于 构造 合适 的 分 支 条 件 和 分 析 程 序 流程 ,根据 不 同 的 逻辑 和 比较 运算 结果 选择 
执行 某 段 程序 。PHP 提供 了 If…ElseIf…Else… 和 Switch Case 两 种 结构 。 





9.2.1 If…Elself…Else… 分 支 结 构 


一 个 ff…Elself…Else… 分 支 结 构 , 是 一 种 块 语句 结构 , 它 由 一 条 If、Else 语句 或 多 条 
Elself 语句 以 及 相关 的 语句 组 构成 。 语 句 执行 过 程 如 图 9-1 所 示 。 
语句 结构 : 


If (分 支 条 件 1) 
语句 组 1 

[ ElseIf (分 支 条 件 2) 
语句 组 2 

ElseIf (分 支 条 件 3) 
语句 组 3 
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图 9-1 I 语句 控制 流程 图 


E ] 
[Else 
语句 组 n 妃 ] 

在 设计 语句 结构 时 ,分 支 条 件 i(1<i<n) 是 值 为 逻辑 型 的 表达 式 ; 语 句 组 n 由 大 括号 
“| 1" 括 起 来 的 多 条 语句 组 成 , 仅 有 一 条 语句 时 ,大 括号 可 以 不 写 。 

在 执行 f…Elself…Else… 分 支 结构 时 ,系统 从 分 支 条 件 1 开始 分 析 判 断 。 如 果 分 支 
条 件 i 的 值 为 True( 真 ) , 则 执行 语句 组 i; 如 果 所 有 分 支 条 件 均 不 成 立 ( 值 为 False) , 且 有 
Else 语句 , 则 执行 语句 组 n+ 1。 每 执行 完 一 个 语句 组 ,都 结束 本 下 块 语句 选 择 结构 。 

【 例 9.9】 完善 例 9.3, 输 入 刘 德 厚 王 丽 敏和 李 丽 丽 以 外 的 姓名 时 ,不 会 引发 系统 
出 错 。 

<Form Action ="" Method ="post" > 


姓名 : <Input Name ="xm" Type ="Text" /> 
<Input Type ="Submit" Name ="Button" Value 了 提交 " /></Fom> 


<?PHP If (Tsset ( $ POST ["Button"])) // 用 户 单 击 "提交 "按钮 时 为 True 
{ $a=$ POST["xm"]; // 省 略 ElseIf 和 柜 se 外 层 分 支 ,语句 组 中 
多 条 语句 ,用 { 开 始 


Score [" 刘 德 厚 "] =80; 
Score [" 王 丽 敏 "] <95; 
Score [" 李 丽 丽 "] 337; 
If ( 扣 == 刘 德 厚 " Or 经 = 了 王 丽 敏 " Or 知 ==" 李 丽 丽 ") 
// 省 略 本 seIf 的 里 层 双 分 支 结构 


Echo $score[ $a]; // 语句 组 中 一 条 语句 ,“{ }" 可 以 省 略 
Else 
Echo " 没 找到 : " $a; // 语句 组 中 一 条 语句 ,“{ }" 可 以 省 略 


} // 结束 外 层 结构 的 大 括号 ?> 
【 例 9.10】 将 输入 的 面试 成 绩 转化 成 对 应 的 等 级 : 90 分 及 以 上 为 优秀 ,80 ~ 89 为 
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良好 ,60 ~79 为 合格 , 低 于 60 分 为 不 合格 。 


<Eorm Action 一 '" Method ="Post" > 
面试 成 绩 : <Input Name "cj" Type ="Text" /> 
<Input Type ="Submit" Name ="Button" Value =" 提 交 " / ><Fom> 
<?PHP If (Isset ($ POST["Button"])) 
{ $a=$ POsT["cj"]; 
IfE( 拓 >-90g& $a<300) 


Echo "优秀 "; // 语句 组 中 一 条 语句 必 { ] "可 以 省 略 
ElseIf( $a >=80) 

Echo "良好 "; // 语句 组 中 一 条 语句 ,“{ }” 可 以 省 略 
ElseIf( $a >=60) 

{ Echo "合格 ";} // 语句 组 中 一 条 语句 也 可 以 用 * { }” 
Else 

Echo "不 合格 "; // 语句 组 中 一 条 语句 ,大 括号 可 以 省 略 


} ?> 


当 输入 的 数据 为 95 时 ,输出 结果 为 “优秀 ” ,尽管 条 件 $a > =80 和 $a> =60 也 得 到 
满足 ,但 是 ,不 会 执行 对 应 的 分 支 。 这 说 明 于 选择 结构 中 ,最 多 只 执行 一 个 分 支 。 


9.2.2 Switch Case 分 支 结 构 


Switch Case 分 支 结构 用 Switch 语句 开始 ,由 若干 条 Case 和 一 条 Default 语句 以 及 若 
干 个 语句 组 构成 。 
语句 结构 : 
Switch (表达 式 ) 
{ Case 分支 条 件 1: 
语句 组 1 
Case 分 支 条 件 2: 
语句 组 2 





Case 分 支 条 件 n: 抽 和 Break 


语句 组 n 
[ Default: 
语句 组 n 术 ] 】} 
语句 结构 执行 过 程 如 图 9-2 所 示 。Switch 
(表达 式 ) 可 以 是 任何 数据 类 型 的 表达 式 , 通 常 
为 Case 分 支 条 件 判 断 提供 数据 依据 。 在 写 每 
个 Case 分 支 条 件 时 , 如果 使 用 “Case 表达 式 语句 组 m+1 


= = 值 "的 形式 , 则 可 以 简写 成 “Case 值 ” ,通常 
用 于 可 枚 举 数据 的 分 析 判 断 。 CG 


在 执行 Switch Case 分 支 结构 时 ,系统 从 分 图 9-2 ”Switch Case 语句 控制 流程 


语句 组 1 








证 本 | 热 GBreak 











语句 组 n 执行 Break 
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支 条 件 1 开始 分 析 判 断 ,如 果 分 支 条 件 i(1<i=<n) 的 值 为 True, 则 执行 语句 组 i; 如 果 所 有 
分 支 条 件 都 不 成 立 ( 条件 值 为 False) , 且 有 Default 语句 , 则 执行 语句 组 n+1。 

在 执行 任何 语句 组 i(1<i<n) 的 过 程 中 ,如 果 执 行 到 Break 语句 , 则 结束 本 Switch 
Case 分 支 结构 ;如 果 执 行 完 语句 组 i 的 过 程 中 没 执行 到 Break 语句 , 则 继续 执行 语句 组 
i+1 及 后 面 的 语句 组 ,甚至 可 能 执行 到 语句 组 n+1 ,即使 分 支 条 件 i+1 及 后 面 的 分 支 条 
件 都 不 成 立 ,也 是 如 此 。 

【 例 9.11】 在 人 才 招 聘 过 程 中 ,假定 学 历 越 高 ,可 以 胜任 的 职务 越 多 ,在 文本 框 中 输 
入 学 历 , 输 出 其 可 以 胜任 的 职务 。 


<Eorm Action ="" Method ="Post" > 
学 历 : <Input Type "Text" Name "x1" /> 
<Input Type 2"'Submit" Name ~"Button" Value 二 提交" / ></Fom > 
<?PHP If (Isset ( $ POST["Button"])) 
{ =$ POST["x1"]; 
Switch ($a) 
{ Case "博士 ": Echo "总 经 理 "; // 条 件 为 知 = 志 博士 ", 省 略 了 分 == 
Case "研究 生 ": Echo "经 理 "; // 条 件 为 所 ==" 研 究 生 " 
Case "本 科 ": Echo "业务 员 "; 。”// 条 件 为 提 == 本 科 " 
Default :Echo "其 他 "; } 
} ?> 


执行 上 面 程序 时 ,如果 学 历 输 入 “博士 " , 则 输出 “总 经 理 经 理 业 务 员 其 他 ” , 即 当 
Switch 后 的 变量 $a 的 值 与 第 一 个 Case 后 的 “博士 "相等 , 则 执行 对 应 的 语句 组 ,但 没 执 
行 到 Break 语句 ,因此 ,执行 了 整个 结构 中 的 每 个 分 支 。 如 果 将 程序 改 成 如 下 形式 : 


<Eorm Action ="" Method ="Post" > 
学 历 : <Input Type ="Text" Name ="xl" /> 
<Input Type ="Submit" Name ="Button" Value = 提交" / ></Fom> 
<?PHP If(Isset($ POST["Button"])) 
{ $a=$ POST["x1"]; 
Switch ( $a) 
{ ”Case "博士 ": Echo "总 经 理 "; 
Case "研究 生 ": Echo "经 理 "; Break; 
Case "本 科 ": Echo "业务 员 "; Break; 
Default :Echo "其 他 "7 } 


}?> 
执行 程序 时 学 历 输入 “博士 ” ,并 单 击 “ 提 交 ” 按 钮 后 ,输出 “总 经 理 经 理 ”, 即 Break 语 
句 结束 了 整个 分 支 选择 结构 。 


【 例 9.12】 利用 Switch 结构 ,实现 例 9. 10 的 功能 要 求 。 


<Eorm Action ="" Method ="Post" > 
面试 成 绩 : <Input Type ="Text" Name 一 cj" /> 
<Input Type ="'Submit" Name ="Button" Value "提交 " /><Fom> 
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<?PHP If (Isset(S$S POST["Button"])) 
{ $a=$ POST["cj"]; 
Switch ($a) 
{ Case 和 a >-90 && 各 < 习 00: Echo "优秀 "; Break; 
Case 得 >-80 && 委 <90: Echo" 良 好 "7 Break; 
Case ” 拓 >-60 && $a B80: Echo" 合 格 "; Break; 
Case 名 > 必 && 名 <60: Echo "不 合格 "; Break; 
Default: Echo " 非 百 分 成 绩 !"; } 
} ?> 


9.3 循环 结构 程序 设计 


循环 结构 用 于 解决 重复 处 理 有 变化 规律 的 问题 。 例 如 求 1 + 2 + … + 100 的 结果 , 需 
要 进行 多 次 加 法 ,每 次 都 是 在 上 一 次 求 和 的 基础 上 加 一 个 新 数 。 

循环 结构 是 指 在 执行 程序 的 过 程 中 有 条 件 地 重复 执行 某 个 程序 段 。 重 复 执行 的 程序 
代码 段 被 称 为 循环 体 ,重复 执行 循环 体 的 次 数 称 为 循环 次 数 。 根 据 判断 循环 条 件 和 执行 
循环 体 的 先后 顺序 ,可 以 分 当 型 和 直到 型 两 种 循环 。 

在 循环 体 中 ,可 以 执行 Break 语句 结束 整个 循环 结构 ,也 可 以 执行 Continue 语句 提前 
结束 本 次 循环 , 转 去 判断 循环 条 件 。 


9.3.1 While 循环 结构 


While 循环 结构 由 While( 循环 条 件 ) 语 句 和 循环 体 语句 组 构成 ,属于 当 型 循环 结构 。 

语句 结构 

While (循环 条 件 ) 

循环 体 语句 组 

While 循环 结构 的 执行 流程 如 图 9-3 所 示 。 首 先 判断 循环 条 件 , 当 循环 条 件 为 True 
( 真 ) 时 ,执行 循环 体 语句 组 。 当 执行 一 次 循环 体 语句 组 正常 结束 后 ( 指 没 执行 到 Break 
和 Continue 语句 ) , 转 到 While (循环 条 件 ) 语 句 判 断 
循环 条 件 , 如 果 循环 条 件 为 True, 则 再 执行 一 次 循环 CFM ) 
体 语句 组 , 依 此 类 推 ,直到 循环 条 件 为 False( 假 ) , 才 
跳出 循环 体 , 执 行 循 环 结 构 后 面 的 语句 。 

在 执行 循环 体 语句 组 的 过 程 中 ,如 果 执 行 到 
Continue 语句 , 则 提前 结束 本 次 循环 , 转 到 While ( 循 
环 条 件 ) 语 句 判断 循环 条 件 ; 如 果 执 行 到 Break 语句 ， 












执行 Continut 执行 Break 




















则 提前 结束 循环 结构 ,执行 循环 结构 后 面 的 语句 。 
【 例 9.13】 编写 程序 ,计算 1 ~ 100 之 间 所 有 整 
数 的 平方 和 。 图 93” 当 型 循环 控制 流程 
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<?PHP 得 刁 7 Sum-07 
While( 信 < 导 00) 
{ $sum=$sum+Pow (分 ,2); 人 + } 
Echo " $sum"; ?> 


在 例 9. 13 中 ,首先 将 变量 $i 和 $sum 的 初始 值 设 定 为 0, 再 判断 循环 条 件 $i 小 于 
或 等 于 100 是 否 成 立 。 如 果 成 立 , 则 执行 循环 体 中 的 语句 , 且 每 次 循环 体 执行 都 使 得 变量 
$i 的 值 加 1; 当 $i 的 值 为 101 时 ,条 件 不 再 成 立 ,循环 过 程 结束 ,程序 输出 结 
为 338350。 

【 例 9.14】 编写 程序 ,输出 前 100 个 能 被 2 和 3 同时 整除 的 正 整数 。 


<?PHP hn; Sum-07 
While (True) // 循环 条 件 为 恒 真 True 

{ n+ 
IE (!($n $2=-0 And Sn $3=-0)) Continue; // 转 到 While (True) 执 行 
Snum++; 
Echo “Wy", Snum, bd "Ws 
If ($num=3400) Break; // 跳出 循环 体 , 转 去 执行 Echo "循环 结束 !" 语 句 } 

Echo "循环 结束 !"; ?> 


9.3.2 Do…While 循环 结构 


语句 结构 : (GF) 


Do 人 


执行 Break 



























循环 体 语句 组 语句 组 
While (循环 条 件 ) ; 执行 Continue 
Do…While 循环 结构 属于 直到 型 循环 。 先 Te < 
执行 循环 体 ,然后 再 判断 循环 条 件 是 否 成 立 ， 
成 立 则 继续 执行 循环 体 ,直到 循环 条 件 不 成 立 i 
为 止 。 循环 体 最 少 执行 1 次 ,执行 到 Continue 
语句 时 ,提前 结束 本 次 循环 ;执行 到 Break 语句 图 94 ”直到 型 循环 流程 
时 ,提前 结束 循环 结构 , 控制 流程 如 图 94 
所 示 。 
【 例 9.15】 设计 能 计算 1 ~ 100 之 间 所 有 整数 累加 和 的 程序 。 
<?PHP 
全 习 ; Ssum-0; 
Do // 循环 开始 语句 


{ S$sum=$sum+$i; 人 + } 
While (人 < 所 00); 
Echo "结果 是 $sum"; ?> 
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如 果 例 9. 13 和 例 9.15 中 变量 $i 的 初始 值 都 设 为 101 , 则 例 9. 13 中 没有 执行 到 循环 
体 , 输 出 结果 为 0 ,而 例 9. 15 中 执行 1 次 循环 体 ,输出 结果 为 101。 


9.3.3 For 循环 结构 


For 循环 结构 是 当 型 循环 的 另 一 种 表现 形式 ,语句 虽然 比较 复杂 ,但 是 For 语句 使 用 
起 来 更 灵活 ,完全 可 以 代替 While 语句 。 

语句 结构 : 

Eor( [语句 1 ] ; 循环 条 件 ; [ 语句 2] ) 

循环 体 语句 组 

For 语句 结构 中 除了 循环 体 语句 组 外 ,还 有 两 个 部 分 ,彼此 之 间 用 分 号 分 隔 开 , 分 号 
不 能 省 略 。 语 句 1 在 循环 开始 时 执行 一 次 。 循 环 条 件 用 来 控制 循环 结构 的 执行 与 结束 ， 
如 果 条 件 为 真 , 则 执行 循环 体 语句 组 ,否则 结束 循环 结构 。 每 次 循环 体 语句 组 执行 后 自动 
执行 语句 2。 在 执行 循环 体 语句 组 的 过 程 中 ,执行 到 Continue 语句 时 ,提前 结束 本 次 循 
环 ; 执 行 到 Break 语句 时 ,提前 结束 循环 结构 ,控制 流程 如 图 9-5 所 示 。 


ss 循环 条 件 
本 Break 
执 和 Break 。「 全 坏 体 语 条 组 






































执行 Continue 


图 9-5 For 循环 结构 流程 图 


【 例 9.16】 用 For 循环 结构 实现 例 9. 15 的 要 求 。 
<?PHP SSum-0; 

For (复习 ;和 il< 刁 00; 笠 +H SSum=SSum+ 人 7 

Echo "结果 是 SSum"; ?> 
与 例 9.15 比较 ,本 例 用 For 循环 结构 设计 的 程序 要 简单 一 些 。 与 例 9. 15 的 程序 结 
构 和 功能 相同 的 代码 如 下 : 

<?PHP 人 久居; Ssum-07 

For (; 人 1 < 本 007) // 省 略语 句 1 和 语句 2, 但 分 号 不 能 省 略 

{ SSum=SSum+Si; 位 + 七 } 
Echo "结果 是 SSum"; ?> 
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9.3.4 循环 府 套 


一 个 循环 体内 又 包含 另 一 个 完整 的 循环 结构 称 为 循环 结构 嵌 套 。 内 循环 体内 还 可 以 
嵌 套 循环 结构 ,这 就 是 多 层 循 环 结构 。 

3 种 循环 ( While 循环 .Do…While 循环 和 For 循环 ) 可 以 相互 嵌 套 。 

【 例 9.17】 设计 能 输出 九 九 乘法 口诀 表 的 程序 。 


<Table Border ="3" Cellpadding ="3" Cellspacing ="3" > 
<2PHP Echo " <Caption 又 法 口 识 表 </Caption >"; 
For ( 久 习 ;人 儿 <39; 久 + // 外 层 循环 控制 行 数 
{ 人 ;Echo "<tr>"; 
While( 昼 <= 科 ) // 内 层 循环 控制 各 行 的 列 数 
{处 = 位 * 习 ; 
Echo "<td>","$j* 信 =$t"," Ytd>"; 
人 ++t7 } 
Echo " </tr ><br >"; 
}?> </Table> 


在 例 9.17 中 ,While 循环 完全 包含 在 For 循环 结构 中 ,外 层 的 For 循环 体 每 执行 一 
次 ,内 层 循 环 体 执行 $i 次 。 程 序 运行 效果 如 图 9-6 所 示 。 
乘法 口诀 表 








2*2=4 
2*3=6 ||3*3=9 
2*4=8 ||3*4=12||4*4=16 




















2*5=10|[3*5=15|[4*5=20|[5*5=25 
2*6=12|[3*6=18|[4*6=24|[5*6=30|[6*6=36 














2*7=14||3*7=21||4*7=28||5*7=35||6*7=42 








2*8=16||3*8=24||4*8=32||5*8=40||6*8=48 8*8=64 
2*9=18||3*9=27||4*9=36||5*9=45||6*9=54 8*9=72 




































































图 9-6 例 9.17 的 执行 结果 


9.4 数组 的 典型 应 用 


数组 是 名 称 相同 而 下 标 不 同 的 一 组 内 存 变量 ,对 数组 的 典型 应 用 有 数组 元 素 排序 . 查 
找 和 遍历 。 
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9.4.1 数组 元 素 的 排序 


排序 是 实际 应 用 中 比较 常见 的 问题 。 在 PHP 中 ,可 以 用 Sort 函数 对 数组 元 素 进 行 升 
序 排序 。 

函数 格式 : 

Sort (数组 [, 排 序 规则 ]) 


函数 的 作用 是 对 数组 元 素 进行 排序 ,第 一 个 参数 表示 要 进行 排序 的 数组 ,排序 结果 也 
存 回 到 该 数组 ;第 二 个 可 选 参 数 用 于 设置 排序 规则 : 

(1) SORT_REGULAR : 系统 默认 值 , 按 数组 元 素 的 实际 数据 类 型 排序 , 若 有 混合 数据 
类 型 的 元 素 , 则 按 系统 的 规则 排序 。 

(2) SORT_NUMERIC: 所 有 数组 元 素 都 按 数 值 型 进行 排序 ,对 非 数 值 型 ( 如 字符 串 和 
日 期 等 ) 元 素 按 转换 后 的 数值 比较 ,不 可 转换 成 数值 的 元 素 按 0 进行 比较 。 

(3) SORT_STRING: 所 有 数组 元 素 都 按 字 符 串 进行 排序 , 非 字 符 串 (如 数值 和 日 期 
等 ) 元 素 都 按 转换 后 的 字符 串 比 较 。 

在 排序 的 结果 数组 中 ,改变 了 原 数组 中 各 个 元 素 的 位 置 , 但 并 不 改变 数组 元 素 的 数据 
类 型 。 由 于 不 同 数据 类 型 的 数组 元 素 排 序 结果 很 难 预知 ,因此 ,通常 用 Sort 函数 仅 对 相同 
数据 类 型 的 数组 元 素 进行 排序 。 

【 例 9.18】 利用 Sort 函数 排序 输出 一 维 数组 的 元 素 。 

<?PHP $Myarray Array (65,88,73,92,56,80,100,99); 

Sort ( Myarray); 
For (位 性 ;位 < 导 ;位 + 
Echo $Myarray[ $i]," dor>"; ?> 

程序 中 的 Sort( $ Myarray ) 是 按 数组 元 素 的 数据 类 型 (数值 型 ) 进 行 排序 ,输出 结果 
为 : 56 .65 .73 .80 .88 .92 .99 和 100。 

如 果 将 程序 中 的 Sort( $ Myarray ) 修改 为 Sort( $ Myarray,SORT_STRING ) ,数组 元 素 
按 字符 串 型 进行 排序 , 则 输出 结果 为 : 100 .56 .65 .73 .80 .88 .92 和 99。 由 此 可 以 看 出 ,对 
于 同一 个 数组 用 不 同 的 排序 规则 ,产生 的 结果 中 数组 元 素 的 顺序 不 同 。 


9.4.2 数组 元 素 的 查找 

查找 (检索 或 搜索 ) 数 组 元 素 是 对 数组 常见 的 一 种 操作 ,PHP 提供 了 一 组 快速 检索 数 
组 元 素 的 函数 。 

1. In_Array 函数 


函数 格式 
In_array (关键 字 的 值 ,数组 名 ) 
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调用 该 函数 在 数组 中 检索 关键 字 的 值 ,如 果 找 到 与 关键 字 的 值 相等 的 元 素 , 则 函数 返 
回 True ,否则 返回 False。 
【 例 9.19】 在 文本 框 中 输入 一 个 职务 ,判断 其 是 否 已 经 在 数组 $ Jobs 中 。 


<Form Action ="" Method ="Post" > 
<Input Type ="Text" Name ="job" /> 
<Input Type ="Submit" Name ="Button" Value 二 提交" /> </Fom> 
<?PHP If (Isset ($ POST["Button"])) 
{ $IJob =$ POST["job"] ; 
S$Jobs Array ("文员 ", "主管 ", "助理 ", "经 理 "); 
If( In Array( $Job, $Jobs)) Echo " SUcb 已 经 在 数组 中 "; 
Else Echo " $Job 不 在 数组 中 "; } ?> 


输入 “主管 " ,并 单 击 提交 按钮 后 输出 : 主管 已 经 在 数组 中 。 
2. Array_Search 函数 


函数 格式 : 
Array_Search (关键 字 的 值 ,数组 名 ) 
调用 该 函数 在 数组 中 检索 关键 字 的 值 ,如 果 找 到 与 关键 字 的 值 相 等 的 元 素 , 则 函数 返 
回 该 元 素 的 下 标 值 ,否则 返回 False。 
【 例 9.20】 查找 文本 框 中 输入 的 职务 在 数组 $ Jobs 中 是 否 存 在 ,如 果 存 在 , 则 输出 
其 下 标 值 。 
<orm Action ="" Method ="Post" > 
<Input Type ="Text" Name 2"job" /> 
<Input Type ="Submit" Name ="Button" Value =>" 提交" /> </Fom> 
<?PHP If (Isset ( $ POST["Button"])) 
{ Soob =$ POST["jcb"] ; 
$cbs rray ("a" =>" 主 管 " "mb" =>" 助 理 ","c" =>" 经 理 "); 
$t Array_Search ( SJob, $Jobs); 
If( 处 ==false) Echo " $Job 不 在 数组 中 "; 
Else Echo " $Job 在 数组 中 ,序号 是 入 "7 
全 
当 输 入 “助理 "并 单 击 提交 按钮 后 ,程序 输出 结果 为 : 助理 的 下 标 值 是 : b。 
PHP 还 提供 了 Array_Key_Exists( ) 和 Array_Keys( ) 等 数组 元 素 查找 函数 ,功能 与 调 
用 方法 与 上 述 函 数 类 似 。 


9.4.3 ”遍历 数组 


所 谓 遍 历数 组 就 是 访问 ( 读 或 取 ) 数 组 中 的 每 个 元 素 一 次 , 且 仅 一 次 的 操作 。 用 循环 
结构 设计 的 程序 可 以 遍历 数组 ,PHP 还 提供 了 专用 遍历 数组 的 循环 语句 。 
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语句 格式 : 
ForEach (数组 名 as [ 变量 名 1 = 习 变 量 名 2 
循环 体 语句 组 

从 数组 中 的 第 一 个 元 素 开 始 , 依 次 将 数组 每 个 元 素 的 下 标 值 赋 给 变量 1( 可 省 略 ) ,元 
素 的 值 赋 给 变量 2。 在 循环 体 语 句 组 中 ,通过 变量 名 1 可 以 引用 元 素 的 下 标 ;通过 变量 名 
2 可 以 引用 元 素 的 值 。 

【 例 9.21】 输出 数组 $ Jobs 中 的 全 部 元 素 。 

<?PHP ”SUobs array ("1"=>" 经 理 ","2"=>" 经 理 助理 ","3"=>" 理 财 顾问 ") ; 

ForEach ( $Jobs as Salue ) // 省 略 变量 名 1, 仅 将 元 素 的 值 存 于 Svalue 
Echo SValue." dr>"; ?> 
程序 输出 结果 为 : 经 理 ,经 理 助 理 和 理财 顾问 
【 例 9.22】 输出 数组 $ Jobs 中 的 全 部 元 素 的 值 。 


<?PHP ”$$Jobs array ("1"=>" 经 理 ","2"=>" 经 理 助 理 ","3"=>" 理 财 顾 问 "); 
ForEach ( $Jobs as $key=> Walue) Echo " $key => Walue br >"; ?> 


程序 的 输出 结果 为 : 1 = > 经 理 .2 = > 经 理 助 理 和 3 = > 理财 顾问 。 


9.5 获取 表单 控件 数据 的 程序 设计 


由 于 HTML 仅 用 于 设计 静态 网 页 ,没有 数据 深加工 能 力 , 因 此 ,浏览 咒 表 单 上 (窗口 ) 
输入 的 数据 还 需要 获取 到 PHP 程序 中 ,进一步 处 理 和 加 工 ,或 者 , 依 此 为 基础 访问 数据 
库 。PHP 程序 获取 表单 控件 数据 有 Post 和 Get 两 种 方法 。 具 体 采 用 哪 种 方法 由 表单 的 
Method 属性 的 值 (Post 或 Get) 决定。 

PHP 预定 义 了 $ _POST 和 $ _GET 两 个 超 全 局 关联 数组 ,分 别 用 于 存储 Post 和 Get 
方法 传送 的 表单 控件 数据 ,元 素 的 下 标 值 是 表单 控件 的 Name 属性 值 ( 名 称 ) 。 


9.5.1 调用 PHP 程序 的 表单 设计 


为 了 使 PHP 程序 能 获取 表单 控件 上 输入 的 数据 ,在 用 户 单 击 表 单 上 的 命令 按钮 (如 
注册 ,登录 和 提交 按钮 等 ) 后 需要 执行 PHP 程序。 在 设计 程序 时 应 该 设计 能 调用 PHP 程 
序 的 表单 ,在 表单 中 调用 PHP 程序 通常 有 用 户 单 击 提交 按钮 捕捉 和 触发 两 种 方式 。 


1. 捕捉 用 户 单 击 提交 按钮 


这 种 方式 将 定义 表单 和 获取 表单 控件 数据 的 程序 存 于 同一 个 PHP 文件 中 ,在 定义 表 
单 时 ,将 Action 属性 值 设 为 “#”( Action ="#" ) ;在 PHP 程序 中 ,通过 IsSet( ) 函数 捕捉 用 
户 单 击 提交 (Type = "Submit" ) 或 图 像 (Type =" Image" ) 按 钮 的 时 机 ,以 便 执行 PHP 程序 。 
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例如 ,第 8 章 中 的 例 8. 17 就 是 这 样 的 例题 。 
2. 单 击 提交 按钮 触发 PHP 程序 


这 种 方式 通常 将 定义 表单 (HTML) 和 获取 表单 控件 数据 的 PHP 程序 分 两 个 文件 存 
储 , 当 定义 表单 时 ,Action 属性 说 明 要 调用 的 PHP 程序 文件 名 , 当 用 户 单 击 浏览 器 中 表单 
的 提交 (Type = "Submit" ) 或 图 像 (Type = " Image" ) 按钮 时 ,系统 自动 触发 (执行 ) 对 应 的 
PHP 程序 文件 。 

【 例 9.23】 设计 如 图 9-7 所 示 的 应 聘 人 员 注 册 信息 表单 网 页 文件 YPRYZC. HTML。 





身份 证 号 : [229901199503121538 
姓 名 : | 刘 德 厚 


2013 年 9 月 高 中 ……， 
2015 年 通过 全 国 计 算 机 考试 二 级 。 

















个 人 简历 : 
最 后 学 历 ， @ 无 OO 专科 @ 本 科 OO 研究生 OO 博士 生 


外 语 语种 口 无 回 英语 口 日 语 回 舱 语 口 其 他 


加 
特长 : 图: 学 位 ，| 双 学 士 国 


要 附加 的 佐证 资料 文件 
图 本 
























































图 9-7 应 聘 人 员 注 册 表 单 


YPRYZC. HTML 中 的 代码 如 下 : 


<HIML ><Head > 
<Meta http -equiv ="Content -Type" Content ="text/html; CharSet utf -8" /> 
<Title 六 聘 人 员 注 册 </Title ></Head > 
<Body> 
<Form Action ="YPRYZC .PHP" Method ="Post" Name ="fml" Target =" new" 
ENCType ="Multipart/Form -Data" > 
身份 证 号 : <Input Type ="Text" Name <"'SFZH" Size "18" Maxlength="18" />dr> 
姓 名 : <Input Type ="Text" Name ="XM" Value =" 匿 名 " Size ="'5" ><br > 
个 人 简历 : <TextArea Name "JL" Cols ="50" Rows ="3" ></TextArea ><br > 
最 后 学 历 : 
<Input Type ="Radio" Name ="XL" Value 刁 Checked/ 汇 
<Input Type ="Radio" Name "XL" Value 之 /法科 
<Input Type ="Radio" Name ="XL" Value 续 / 亲 科 
<Input Type "Radio" Name "XL" Value 寺 4 / > 研究 生 
<Input Type ="Radio" Name ="XL" Value 起 / 清 士 生 Zzbr > 
也 外语 语种 : 
<Input Type ="CheckBox" Name 2"WY[]" Value -0 Checked / 汇 
<Input Type "CheckBox" Name "WY[]" Value 习 /并 语 
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<Input Type "CheckBox" Name ="WY[]"” Value 之 / 间 语 

<Input Type "CheckBox" Name =WY[]"” Value / 痊 语 

<Input Type "CheckBox" Name "WY[]"” Value 了 / 淇 他 </P> 

特长 : <Select Name ="TC[]" size 性 mltiple > 
<Option Value 本 : 体 育 </option> 
<Dption Value 之 六 艺 </Option> 
<Option Value 汉 阐 f 交 </option > 
<Option Value 了 Selected 并 他 </Option ></Select > 

学 位 : <Select Name "XW" > 
<Option Value 习 交 </Option > <Option Value 之 Selected 六 十 <option> 
<Option Value 污 > 汉学 士 </Option > <Option Value 4 颈 士 </Option > 
<option Value 起 靖 士 Option ></Select > 

起 对 附 加 的 佐证 资料 文件 
<Input Type =File" Name =FU" ></P> 

< ><Input Type ="Submit" Name ="ZC" Value " 注 册 " /> 
<Input Type ="Reset" Name "CZ"” Value 一 重 置 " /></P> 

</Form > </Body > </HIML > 


在 YPRYZC. HTML 文件 中 ,由 于 表单 中 包含 文件 (Type = "File" ) 域 控件 ,因此 表单 编 
码 类 型 Enctype 属性 值 必须 设 为 Multipart/Form-Data。 男 外 ,表单 的 Action 属性 值 为 
ZCYPRY. PHP ,注册 按钮 的 Type 属性 值 为 Submit ,因此 ,在 浏览 器 中 显示 表单 时 , 单 击 * 注 


册 ” 按 钮 ,系统 将 自动 执行 程序 文件 ZCYPRY. PHP。 


9.5.2 获取 表单 控件 的 数据 


获取 表单 控件 的 数据 实质 上 是 将 各 种 控件 上 输入 或 选择 的 数据 获取 到 PHP 程序 中 ， 


以 便 对 数据 进一步 处 理 或 存储 。 
1. 获取 单 值 控件 的 数据 


单 值 控件 是 指 一 次 运行 用 户 只 能 输入 或 选择 一 个 数据 的 控件 。 用 于 输入 数据 的 单 值 


控件 有 文本 框 (Type = Text, 如 身份 证 号 和 姓名 ) 、 密 码 框 ( Type = Password ) 和 文本 





区 域 


(Type = Textarea ,也 称 编辑 框 ,如 个 人 简历 ) ,可 以 通过 键盘 输入 ,条 码 IC 卡 或 二 维 码 等 
扫描 输入 ,数据 存 于 $_POST[ 控件 名 ] 或 $_GET[ 控 件 名 ] 元 素 中 。 数 据 存 于 哪个 元 素 ， 


由 表单 的 Method 属性 值 是 Post 或 Get 来 决定 。 


用 于 选择 数据 的 单 值 控件 有 单 选 按钮 组 ( Type = Radio, 如 最 后 学 历 ) 和 菜单 (也 称 下 


拉 列 表 框 ,如 学 位 ) ,通常 用 键盘 或 鼠标 选中 其 中 1 个 选项 ,将 选中 项 对 应 控件 的 Value 属 


性 值 存 于 $_POST[ 控件 名 ] 或 $_GET[ 控 件 名 ] 元 素 中 。 





在 PHP 程序 中 ,可 以 直接 引用 $_POST[ 控件 名 ]( 如 $_POST["SFZH" ] 和 $_POST 


["XL"]) 或 $_GET[ 控 件 名 ] 元 素 即 可 获取 对 应 控件 的 数据 。 
2. 获取 多 值 控件 的 数据 


多 值 控件 是 指 每 次 运行 用 户 可 以 选择 多 个 数据 的 控件 。 复 选 框 (Type = Checkbox, 如 
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外 语 语种 ) 和 列表 框 (如 特长 ) ,一 般 通过 鼠标 或 键盘 可 以 选中 多 个 选项 ,将 选中 项 对 应 控 
件 的 Value 属性 值 存 于 $_POST[ 控件 名 ] 或 $_GET[ 控件 名 ] 数 组 中 。 

在 PHP 程序 中 ,需要 通过 循环 结构 (如 For 和 ForEach 等 ) 引 用 $_POST[ 控件 名 ] 
(如 $_POST["WY"] 和 $_POST["TC"]) 或 $_GET[ 控 件 名 ] 数 组 中 的 各 个 元 素 。 


3. 获取 文件 域 的 数据 


文件 域 允许 用 户 选择 一 个 文件 , 选 定 文 件 的 绝对 存储 路 径 存 于 $_POST[ 控件 名 ] 或 
$_GET[ 控件 名 ] 元 素 中 。 文 件 域 通常 与 超 全 局 数组 $_FILES 配合 使 用 ,以 达到 向 服务 
器 上 传 文件 的 目的 。$_FILES 是 一 个 二 维 数组 ,第 一 个 下 标 是 文件 域 控件 名 ,第 二 个 下 
标 ( 英文 字母 均 为 小 写 ) 如下: 

e name: 上 传 的 文件 名 称 。 

® type: 上 传 的 文件 类 型 。 

e size: 以 字 节 为 单位 的 上 传 文件 大 小 。 

。 tmp_name: 存储 在 服务 器 的 文件 临时 副本 名 称 。 

e error; 如 果 上 传 文件 出 错 , 则 返回 错误 信息 代码 。 

通过 $_FILES 数组 和 Move_Uploaded_File 函数 ,才能 将 文件 域 上 传 的 文件 保存 到 服 
务 器 中 。 

函数 格式 : 


Move Uploaded_ File (临时 文件 名 ,保存 后 的 文件 名 ) 


其 中 ,临时 文件 名 由 系统 随机 生成 ;保存 后 的 文件 名 由 路 径 和 文件 名 组 成 ,如 果 省 略 
路 径 , 则 将 文件 保存 到 当前 PHP 程序 所 在 的 文件 夹 中 。 
【 例 9.24】 设计 能 获取 如 图 9-7 所 示 的 表单 控件 数据 的 程序 文件 YPRYZC. PHP。 


<HIML > <Head > 

<Meta http -equiv ="Content -Type" Content ="text/html; Charset autf -8" / ></Head > 
<Body > <Table width 500 border 之 cellspacing3 cellpadding3 > 

<Caption > 表单 上 输入 的 数据 </Caption > 

<Tr ><Th 激 据 项 名 <rh x 激 据 

<?PHP Echo ' <Tr ><Td > 身份 证 号 <rda >'， $ POST["SFZH"]; // 获取 文本 框 SFZH 的 数据 


Echo ' <Tr ><rdx 姓 名 <Tda>'，S POST["XM"]; // 获取 文本 框 RM 的 数据 

Echo ' <Tr ><Td > 个 人 简历 <rd >'，,$_POST["JL"]; // 获取 文本 区 域 区 的 数据 

Echo ' <Tr ><Td 冀 后 学 历 <rd >',$_POST["XL"]; // 获取 单 选 按钮 辽 的 数据 

Echo ， <Tr ><Td > 外 语 语种 <rd >"'; 

FEor( 和 -0 7; Si<Count($S POST["WY"])7 和 二 和 // 获取 多 选 值 复 选 框 Wy 的 数据 ,需要 循环 


Echo $ POST["WY"] [ $i]." br >"; 
Echo ' <Tr ><Td 六 长 <rd>'; 
ForEach ( $ POST["TC"] as $x) Echo $x," br >"; // 获取 多 选 值 列表 框 TC 的 数据 ,需要 循环 
Echo ' <Tr ><Td 阅 位 <Id >',$ POST["XW"],' </Table >'; // 获取 下 拉 列 表 框 好 的 数据 
IE ($ FILES["FJ"] ["size"]/1024 况 00 ) // 判 断 文件 大 小 ,文件 小 于 200K 
{ IE ($ FILES["FJ"] ["error"] >0) // 判断 文件 上 传 是 否 发 生 错 误 
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Echo "文件 上 传 出 现 错误 sbr >"; 
Else 
Move Uploaded File(S FILES["FJ"] ["tmp name"], 
"doc\\". $ FILES["FJ"] ["name"]); // 文件 转移 到 服务 器 上 doc 文件 夹 中 
Else Echo "无 效 的 文件 "; ?> 
</Body > </HIML > 


在 浏览 器 显示 网 页 文件 YPRYZC. HTML 时 ,输入 相关 信息 ,如 图 9-7 所 示 , 单 击 “ 注 


册 " 按 钮 后 ,浏览 器 中 显示 的 信息 如 图 9-8 所 示 , 用 户 选 定 的 文件 被 上 传 至 当前 网 页 所 在 
目录 下 的 doc 文件 夹 中 。 





表单 上 输入 的 数据 





数据 项 名 | 数据 

身份 证 号 |220104195903121538 

了 名 ” 刚 德 厚 

[个 人 简历 2013 年 9 月 高 中 ……; ”2015 年 通过 全 国 计 算 机 考试 二 级 。 


























图 9-8 获取 的 表单 控件 数据 


9.6 自 定 义 函 数 设 计 


在 编程 的 过 程 中 ,通常 会 通过 函数 实现 某 些 功能 。 函 数 可 以 根据 给 定 的 一 组 参数 完 
成 任务 ,并 且 可 能 返回 一 个 值 。 由 于 一 个 函数 可 以 多 次 调用 ,因此 ,可 以 减少 程序 代码 量 ， 
更 便于 程序 维护 和 修改 。 当 程序 代码 过 多 时 ,通过 函数 组 织 程序 是 一 种 很 好 的 方法 ,这样 
可 以 让 一 段 程序 代码 形成 一 个 程序 模块 , 当 程 序 开发 人 员 需 要 实现 同样 的 功能 时 可 以 直 
接 调用 ,减少 了 重复 编码 的 麻烦 ,提高 了 代码 的 可 重用 性 。 

PHP 函数 可 以 分 为 系统 内 置 函 数 (标准 函数 ) 和 用 户 自 定义 函数 两 种 ,一 个 PHP 函数 
由 四 部 分 构成 : 函数 名 .参数 .函数 体 和 返回 值 。 


9.6.1 用 户 自 定义 函数 的 结构 


用 户 自 定义 函数 结构 : 


Function 函数 名 ( 形 参 1[ :默认 值 1 ],……, 形 参 n[ - 轩 认 值 n ]) 
{ ”函数 体 ”// 完成 函数 功能 的 语句 组 } 
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其 中 Function 是 函数 声明 的 关键 字 , 函 数 名 是 函数 在 程序 代码 中 的 引用 名 ,其 命名 原 
则 与 变量 命名 原则 相同 ,英文 字母 不 区 分 大 小 写 。 给 函数 命名 时 ,函数 名 应 与 函数 的 功能 
相符 ,不 可 使 用 已 声明 的 函数 名 或 系统 内 置 函 数 名 。 

形 参 ( 也 称 形 式 参数 ) 用 于 接收 调用 该 函数 时 传 来 的 数据 ,在 函数 体内 可 参与 各 种 运 
算 , 当 多 于 1 个 参数 时 ,参数 之 间 用 逗号 分 隔 ; 当 函数 不 需要 与 外 部 进行 数据 交换 时 ,可 以 
没有 参数 。 

函数 体 是 实现 特定 功能 的 程序 代码 ,可 以 包含 Return 表达 式 语句 ,表达 式 的 值 即 为 
函数 的 返回 值 。 

【 例 9.25】 自 定义 函数 Myfun ,计算 $n 和 $m 的 乘积 。 

<2PHP 

Function Myfun( $n , $m) 

{ /7 函数 体 中 即使 只 有 1 条 语句 , 花 括 号 作为 函数 体 的 定 界 符 , 不 能 省 上 略 

Return $m* Sn; } ?> 

Myfun 是 函数 名 ,$n 和 $m 是 函数 的 形 参 ,| | 中 的 代码 是 函数 体 ,Return $m* $n 

表示 函数 返回 $m* $n 的 值 。 


9.6.2 了 困 数 的 调用 


像 调 用 系统 内 罩 函 数 一 样 ,在 程序 中 可 以 多 次 调用 同一 个 自 定义 函数 。 

调用 格式 : 

函数 名 ( 实 参 1,……, 实 参 ) 

调用 函数 时 只 需要 给 出 函数 名 ,并 在 后 面 的 括号 中 给 出 所 需 的 实 参 (也 称 实际 参数 ) 
表 , 实 参 是 一 个 与 形 参 位 置 对 应 的 变量 或 表达 式 。 在 PHP 中 ,用 户 自 定义 函 数 写 在 函数 
调用 语句 之 前 或 之 后 均 可 。 

【 例 9.26】 利用 自 定义 函数 计算 数学 表达 式 : 


<Eorm Action ="" Method ="Post" > 
请 输入 m 的 值 : <Input Type ="Text" Name ="m" /> 
请 输入 n 的 值 : <Input Type ="Text" Name ="n" /> 
<Input Type ="Submit" Name ="Button" Value =>" 提交" /> 


</Fom> 
<?PHP 
Function jc( $s) 
{ 处 习 ; // 函数 jc 的 函数 体 
For ( 香 刁 :各 <=S57 和 + 处 = 处 * 全 7 
Return $t; // jc 返回 值 为 先 的 值 } 


If(isset($ POST["Button"])) 
{ 全 3 导 c($ POSTI"m"])/(jc($ POST["n"])* jc(S$ POSTI"m"] -$ POST["n"])); 
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// 3 次 调用 jc 
sc($);1} 
Function sc( $p) 
{ // 函数 sc 的 函数 体 , 花 括号 作为 函数 体 的 定 界 符 , 不 能 省 略 
Echo "计算 的 结果 是 : ", Sp; } ?> 
在 文本 框 中 输入 5 和 3 ,并 单 击 * 提 交 " 按 钮 后 ,输出 的 结果 是 : 计算 的 结果 是 : 10。 
从 上 面 例题 可 以 看 出 ,表达 式 中 3 次 要 求 计 算数 的 阶乘 ,而 每 次 计算 阶乘 的 方法 是 相 
同 的 ,只 是 所 涉及 的 数据 不 同 ,这 里 将 计算 阶乘 的 部 分 封装 到 一 个 函数 中 ,多 次 进行 调用 ， 
大 大 提高 了 代码 的 重复 使 用 率 。 
函数 jc 的 调用 出 现在 函数 定义 之 后 ,而 sc 的 调用 出 现在 函数 定义 之 前 。 从 上 面 例题 
可 以 看 出 ,函数 的 调用 不 但 可 以 单独 出 现 ,也 可 以 作为 表达 式 的 一 部 分 ,或 者 作为 其 他 函 
数 的 实际 参数 来 出 现 。 


9.6.3 ”因数 的 参数 传递 
主 程序 通过 参数 列表 可 以 给 函数 传递 数据 ,在 定义 函数 时 ,参数 被 称 为 形 参 ;在 调用 
函数 时 ,使 用 的 参数 称 为 实 参 。PHP 函数 的 参数 有 值 传递 和 引用 传递 两 种 方式 。 


1. 参数 值 传递 


参数 值 传递 方式 是 指 主 程序 直接 将 表达 式 的 值 传 递 给 函数 , 形 参 和 实 参 拥有 各 自 的 
存储 空间 ,所 以 在 函数 体内 形 参 的 值 发 生变 化 时 ,不 会 影响 实 参 的 值 。 值 传递 的 形 参 对 应 
的 实 参 可 以 是 表达 式 。 

【 例 9.27】 参数 按 值 传递 的 示例 。 


<?PHP 
Function Myfun ( $n) 
{ $n=Mn; 
Echo "$n zr>"; } // 输出 的 值 为 6 
$a 5; Myfun( $a); 
Echo $a; // 没 改变 对 应 实 参 押 的 值 , 输 出 的 值 为 5 ?> 


程序 在 运行 过 程 中 ,调用 函数 时 , 系统 将 变量 $a 的 值 传 给 形 参 $n, 由 于 $a 和 $n 
分 别 占据 不 同 的 内 存 空间 , 故 在 函数 体内 , 形 参 $n 的 值 加 1 后 变 为 6, 而 主 程序 中 实 参 
$a 的 值 仍然 是 5。 


2. 参数 引用 传递 


设计 函数 时 ,引用 传递 (也 称 地 址 传递 ) 方 式 的 形 参 前 要 加 “ &” 符 号 ,表示 与 实 参 共 
用 同一 内 存 空 间 ,因此 , 形 参 的 值 在 函数 体内 发 生变 化 时 ,会 改变 主 程序 中 对 应 实 参 变 量 
的 值 。 引 用 传递 的 形 参 对 应 的 实 参 必须 是 一 个 变量 。 

【 例 9.28】 参数 按 引 用 方式 传递 示例 。 
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Function Myfun (& $n) // 按照 引用 方式 传递 参数 , 形 参 前 加 & 符 号 
{ $n=An; 
Echo "$n <r>"; } // 输出 的 值 为 6 
3; Myfun( $a); 
Echo $a; // 改变 了 对 应 实 参 得 的 值 ,输出 的 值 为 6? > 


在 程序 运行 的 过 程 中 ,系统 将 变量 $a 在 内 存 中 的 地 址 作为 实 参 传递 给 形 参 变量 , 变 
量 $a 和 $n 共用 同一 段 内 存 空间 ,所 以 在 函数 体内 改变 形 参 的 值 ( $n = $n +1) ,将 改 
变 主 程序 中 实际 参数 $a 的 值 (由 5 变 为 6) 。 


3. 形 参 的 默认 值 


在 设计 自 定义 函数 时 ,每 个 形 参 都 可 以 设置 默认 值 ( 形 参 = 默认 值 )。 在 调用 函数 
时 , 形 参 按 从 前 到 后 的 顺序 依次 接收 实 参 的 值 。 对 设置 了 默认 值 的 形 参 ,可 以 省 略 对 应 的 
实 参 , 形 参 值 即 为 默认 值 。 一 旦 省 略 某 个 实 参 ,其 后 的 所 有 实 参 都 必须 省 略 。 

【 例 9.29】 设计 求 aX? +bX +c =0 解 的 函数 及 其 调用 程序 。 


<HIML ><Head > Meta http -equiv ="Content -Type" Content ="Text/HIML; 
Charset =-UTF -8"/ ><Title > 一 元 二 次 方程 </Title ></Head > Body > 
<?PHP // 一 元 二 次 方程 求解 
Echo "X*X 要 2*X0 的 解数 为 "可 ()," <br > <br >"; 
// 省 略 实 参 ,输出 形 参 默认 值 对 应 方程 解 的 个 数 


$x1 3; $x2 3; 

$gs = ( $x1, $2); // 由 于 实 参 $x2 不 可 省 略 ,虽然 实 参 $xl 与 形 参 押 默认 值 相等 ， 
// 但 不 能 省 略 。X* X+3*Xz=0 解 的 个 数 存 于 $gs, 解 一 存 于 
S$x1, 解 二 存 于 $x2 


Echo "X*X 权 *X-0，S5 个 解 , 解 一 是 $x1, 解 二 是 $x2 <br ><br >"; 

$x1 3; $x2 5; $x3 6; 

$gs = ( $x1, $x2, $x3); // 通过 $x1 与 旬 、$x2 与 多 的 对 应 关系 带 回 方程 的 解 ， 
// 但 $x3 对 应 值 传递 参数 $c, 不 会 改变 

Echo "X*X 5X16 改 , $gs 个 解 , 解 一 是 $x1， 解 二 是 $x2，",' $x3 的 值 为 "" $x3 <br >"; 


Function qj (& 弓 居 , & 斩 辽 , $c 性) // 函数 名 qj, 知 和 名 为 引用 传递 参数 ， 
// 5 为 值 传递 参数 ,3 个 参数 均 有 默认 值 
{ If($a=-0) Return 11; // 非 二 次 方程 ,函数 返回 值 为 了 
Spbs=$b* 和 A* Sar $c; 
If( Spbs >0) 
{ ”$c=(-$p+5qrt($pbs))/(2* $a); // 第 一 个 解 存 于 值 传递 参数 $c 
和 =(- 和 -Sqrt(Sbbs))/C2* $a); // 第 二 个 解 存 于 引用 传递 参数 和 


$a=$c; // 第 一 个 解 存 于 引用 传递 参数 押 
Return 2; } // 有 两 个 解 ,函数 返回 值 为 2 
ElseIf( $Spbs =-0) 
{ 知 =-So/Cx $a); // 一 个 解 存 于 引用 传递 参数 押 
Return 1; } // 有 一 个 解 ,函数 返回 值 为 1 
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Else 
Return 0; // 没有 解 , 函 数 返 回 值 为 0 } 
?></Body > </HIML > 


运行 程序 时 ,浏览 器 中 显示 的 结果 如 下 : 

X*X 切 +*X=-0 解 的 个 数 为 2 

X*XH*X-0,2 个 解 ,， 解 一 是 0， 解 二 是 -3 

X*+X45X4+46-0,2 个 解 , 解 一 是 2， 解 二 是 -3，Sx3 的 值 为 6 

在 函数 体内 ,一旦 执行 到 Return 表达 式 语句 ,就 立刻 结束 函数 体 ,并 将 Retur 语句 中 
表达 式 的 值 作为 本 次 调用 函数 的 返回 值 。 从 本 例 可 以 看 出 ,一 个 函数 体内 可 以 有 多 条 
Return 语句 , 即 多 个 出 口 ,但 Return 语句 通常 出 现在 分 支 结构 中 。 

在 程序 中 通过 qj($xl,$x2) 和 dj($xl,$x2,$x3) 调 用 函数 时 , 主 程序 通过 实 参 
$x1 .$x2 或 $x3 向 函数 qj 传递 一 元 二 次 方程 的 三 个 系数 ,函数 qj 向 主 程序 除 返回 方程 
解 的 个 数 外 ,还 通过 $xl 、$ x2 与 引用 传递 形 参 $a 和 $b 的 对 应 关系 带 回 方程 的 解 。 


9.6.4 程序 文件 之 间 的 数据 传递 


通过 链接 或 URL 可 以 实现 程序 文件 之 间 的 数据 传递 。 

地 址 格式 : 

程序 文件 名 ?参数 名 1 - 值 1& 参数 名 2 - 值 2 …… 

其 中 *?”" 后 面 的 内 容 表示 跨越 网 页 文件 的 参数 名 及 其 值 ,多 个 参数 之 间 用 "& "连接 ， 
因此 ,各 个 参数 的 值 中 不 能 含有 “&" 符 号 。 

【 例 9.30】 在 pagel. HTML 中 设计 链接 ,将 岗位 编号 和 身份 证 号 带 入 page2. PHP 中 。 

Pagel. HTML 代码 ; 

<HIML ><Meta http -equiv ="Content -Type" Content ="text/html; CharSet autf -8" /> 

<Body > 

<A href ="page2 .php?GWBH =A0002&SFZH 之 19901199001011351" > 显示 数据 </A > 

</Body > </HIML > 

在 目标 程序 文件 中 ,需要 用 超 全 局 数组 $ _GET[ ] 获 得 它们 的 值 ,Page2. PHP 代码 
如 下 : 


<HIML > Meta http -equiv ="Content -Type" Content ="text/html; CharSet tf -8" /> 


<Body > 
<2?PHP Echo $ GET['GWBH'].' <or >'; // 输出 : A0002 
Echo $ GET['SFZH']; // 输出 : 219901199001011351 
?></Body > </HIML > 


用 参数 传输 汉字 时 应 该 着 慎 , 有 时 传输 数据 会 出 现 传 输 错误 或 乱码 。 例 如 ,将 “ 岗 前 
培训 师 ” 作 为 参数 值 传输 时 ,可 能 传输 结果 变 成 “ 岗 前 培训 帐 ” 。 
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9.7 变量 作用 域 


变量 作用 域 是 指 一 个 变量 一 旦 定义 后 能 够 被 使 用 的 范围 。 从 技术 上 来 讲 ,作用 域 就 
是 定义 变量 的 有 效 范围 ,变量 必须 在 有 效 范围 内 使 用 ,如 果 超 出 了 有 效 范围 , 则 变量 无 法 
使 用 。 

在 PHP 中 ,根据 变量 作用 域 不 同 , 可 分 为 超 全 局 变量 全 局 变量 .函数 局 部 变量 和 函 
数 静 态 变 量 。 超 全 局 变量 ,如 $ _SESSION、$ _POST 或 $_GET, 作 用 域 是 链接 的 所 有 
PHP 程序 文件 ,或 者 ,触发 关联 的 PHP 程序 文件 ;全 局 变量 也 称 文件 级 变量 ,是 指 PHP 程 
序 中 ( 非 函数 体 ) 直接 赋值 (定义 ) 的 变量 ,作用 域 是 定义 变量 所 在 的 PHP 程序 文件 中 的 
各 个 程序 段 。 


9.7.1 函数 局 部 变量 
将 函数 体内 定义 的 变量 称 为 函数 局 部 变量 ,作用 域 为 所 在 的 函数 体 ,在 函数 运行 结束 


时 ,系统 自动 清除 变量 及 其 值 。 
【 例 9.31】 函数 局 部 变量 示例 。 





<?PHP 
Function Example () 
{全 xa 1 一 "局 部 变量 "; // 包 xa_ 1 仅 在 Example 函数 体内 可 用 
Echo " SExa 1 <br >";} 

Example (); 

Echo 色 xa 1; // 出 错 , 多 xa 1 在 Example 函数 体外 无 效 ?> 

由 于 变量 由 Exa_l 定义 在 函数 Example( ) 中 , 故 在 函数 中 可 以 正常 引用 变量 并 将 其 
输出 ,而 最 后 一 行程 序 由 于 是 在 函数 体 以 外 引用 $ Exa_1, 超 出 了 其 作用 域 ,所 以 程序 
出 错 。 

如 果 全 局 变量 与 函数 局 部 变量 同名 , 则 系统 视 为 两 个 不 同 的 变量 。 

【 例 9.32】 函数 局 部 变量 与 全 局 变量 同名 的 示例 。 


<?PHP $a 3; 
Function Example () 
{ Echo $a; // 出 错 ,在 函数 体内 不 能 直接 引用 全 局 变量 乱 
$0; } // 函数 体 中 给 知 赋 值 ,不 改变 全 局 变量 押 的 值 
Example (); 
Echo $a; // 输出 全 局 变量 拓 的 值 :5 ?> 


当主 程序 调用 Exapmle 函数 时 ,函数 体内 不 能 直接 引用 全 局 变量 $ a, 即使 定义 了 变 
量 $a($a=10) 与 全 局 变量 同名 ,但 也 不 会 改变 全 局 变量 $a 的 值 。 
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9.7.2 ”延伸 全 局 变量 的 作用 域 


在 函数 体内 ,通过 Global 语句 可 以 延伸 一 些 全 局 变量 的 作用 域 。 
语句 格式 : 


Glcbal 全 局 变量 名 表 
【 例 9.33】 Global 定义 全 局 变量 示例 。 


<?PHP $a ="hello"; 
$b "PHP 语言 "; 


Function Example () 

{ Global $b, $c; // 延伸 全 局 变量 和 和 $c 的 作用 域 到 函数 体 
Echo $a; // 没 用 Global 语句 延伸 押 , 语 句 出 错 
Echo S，" <br >"; // 引用 全 局 变量 和 ,输出 : PHP 语言 
$c 32; } // 为 全 局 变量 包 赋 值 

Exanple (); 

Echo $c; // 输出 Example 中 为 包 赋 的 值 : 32 ?> 


主 程序 定义 了 变量 $a 和 $b, 当 调用 函数 Example 时 ,由 于 $a 的 作用 域 属于 主 程 
序 ,并 没有 在 函数 Example 中 定义 ,所 以 系统 出 错 ;而 变量 $b 被 语句 Global 说 明 为 全 局 
变量 ,可 以 延伸 到 函数 中 使 用 。 并 且 , 仅 在 函数 体内 定义 的 全 局 变量 $e ,函数 运行 结束 回 
到 主 程序 后 ,仍然 有 效 。 


9.7.3 ”静态 变量 


静态 变量 仅 在 当前 函数 体 中 有 效 , 当 函数 运行 结束 时 , 系统 仍然 保留 静态 变量 及 其 
值 , 当 再 次 调用 函数 时 ,可 以 在 当前 函数 体 中 延续 使 用 静态 变量 的 值 。 需 要 用 Static 语句 
声明 并 赋值 静态 变量 , 当 再 次 调用 该 函数 时 ,不 再 重新 执行 本 语句 。 

语句 格式 : 

Static 变量 名 1- 值 1,……, 变量 名 n- 值 n 

【 例 9.34】 静态 变量 使 用 示例 。 


<?PHP Sa-0; // 定义 全 局 变量 和 
Function Example () 
{ Sstatic $a30; // 声明 并 赋值 静态 变量 押 
Echo $a," <r>"; 
Satt; } 
Example (); // 输出 结果 为 10 
Example (); // 输出 结果 为 11 
Echo $a," br >"; // 输出 全 局 变量 知 ,结果 为 0 ?> 
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$a 是 静态 变量 , 当 调用 函数 时 ,变量 $a 先 被 设置 为 10 ,然后 输出 其 值 ,变量 $a 再 
进行 自 加 1 运算 ,函数 调用 结束 时 $a 的 值 是 11; 当 再 次 调用 艺 数 时 ,变量 不 会 重新 设置 
为 10 ,而 是 延续 上 次 的 值 , 即 11 ,变量 $a 自 加 1 运算 后 值 为 12。 





9.8 二 维 码 程序 设计 


二 维 码 (Dimensional Barcode) ,又 称 二 维 条 码 , 是 在 条 形 码 (一 维 ) 的 基础 上 扩展 而 来 
的 一 种 平面 条 码 。 相 比 一 维 条 形 码 ,二 维 码 可 以 记载 更 复杂 的 数据 ,如 英文 .汉字 和 图 片 
等 ,相关 设备 仅 扫描 二 维 条 码 ,通过 识别 条 码 的 长 度 和 宽度 所 对 应 的 数据 ,可 获取 相关 信 
息 。 图 片 仅 供 人 们 阅读 参考 ,相关 设备 并 不 识别 。 二 维 码 常用 于 记载 网 络 域名 ,也 逐渐 用 
于 记载 物品 信息 。 

通常 用 PHP QR CODE 类 库 生 成 二 维 码 , 在 设计 生成 二 维 码 的 程序 之 前 ,需要 下 载 
PHPQrcode. PHP 类 库 。 

PHPQrcode. PHP 类 库 提 供 了 生成 二 维 码 的 png( ) 方 法 ,主要 参数 如 表 94 所 示 。 


表 9-4 png( ) 方 法 的 参数 说 明 











参数 使 用 说 明 
$ Text 生成 二 维 码 的 文本 信息 
$ Outfile 保存 二 维 码 图 的 文件 名 
$ Level 容错 率 ,也 就 是 有 被 履 羡 的 区 域 还 能 识别 ,分 别 是 L(QR_ECLEVEL_L,7% ),M( QR 


_ECLEVEL_M,15% ),Q( QR_ECLEVEL Q,25% ),H( QR_ECLEVEL_H ,30% ) 





$ Size 生成 二 维 码 的 大 小 ,默认 是 3 
$ Margin 二 维 码 周 围 边框 空白 区 域 间距 值 
$$Saveandprint ”| 是 否 保存 二 维 码 并 显示 











【 例 9.35】 生成 并 显示 关于 http://www. jlu. edu. cn 的 二 维 码 图 片 文件 JLU. PNG。 


<?PHP If(!file Fxists('JLU.PNG')) 


{ Include 'PHPQRCODE .PHP'; // 装载 类 库 PHPORCODE .PHP 
QRcode: :png ('http://www.jlu.edu.cn', 'JID.PNG'); // 调用 方法 png 生成 二 维 码 图 
> 


<Img Src ="JLU.PNG" Width ="100" Height ="100" /> 


实际 应 用 中 ,在 二 维 码 中 能 入 特定 图 片 (如 LOG0O ) 可 以 增强 宣传 效果 。 那 如 何 生成 
含有 LOG0 的 二 维 码 呢 ? 我 们 先 使 用 PHP QR Code 生成 一 张 二 维 码 图 片 ,然后 再 利用 
PHP 的 Image 相关 函数 ,将 事先 准备 好 的 LOGO 图 片 加 入 到 刚 生成 的 原始 二 维 码 图 片 中 
间 , 然 后 重新 生成 一 张 新 的 二 维 码 图 片 。 

【 例 9.36】 生成 一 个 带 LOGO 并 指向 http://www. jlu. edu. cn 的 二 维 码 。 


<?PHP Include 'Phpqrcode.PHP'; 
SValue ='http://www.jlu.edu.-cn'7 // 二 维 码 内 容 
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邱 rrorCorrectionTevel ="'L"'; 
SMatrixPointSize =6; 
// 生 成 二 维 码 图 片 


// 容错 级 别 
// 生成 图 片 大 小 


QRcode: :png ( Walue, 'JID.PNG', SrrorCorrectionLevel, MatrixPointSize, 2); 


$Logo 一 1ogo-png "7 
SOR ='ULU.ENG ' 

// 再 次 生成 带 LOGO 的 二 维 码 
If ( $Logo ! =-FALSE) 


// 准备 好 的 logo 图 片 
// 已 经 生成 的 原始 二 维 码 图 


{ SoR =magecreatefromstring (File Get Contents ( SOR) ) 
$Logo =Imagecreatefromstring (File Get _ Contents ( SLogo) ) 7 


SR Width =Imagesx( QR); 


SOR _ Height =Imagesy ( OR); 
Sogo Width =Imagesx( $Logo); 
$ILogo Height =Imagesy ( $Logo); 
SLogo Qr Width =SoR Width / 5; 


// 二 维 码 图 片 宽度 
// 二 维 码 图 片 高 度 
// Logo 图 片 宽度 
// Logo 图 片 高 度 





SScale =$Logo Width/ $Logo Qr Width; 
$ILogo Qr Height =$Logo Height/ $5cale; 
全 rom Width =( $0R Width -$Iogo Qr Width) / 2; 


// 重 新 组 合 图 片 并 调整 大 小 


Imagecopyresampled ( $R, $ILogo, $FErom Width, $From Width, 0, 0, 
$ILogo Qr Width, $ILogo Qr Height, $Iogo Width, $Logo Height); } 


Imagepng ( QR, 'hellojlu.png'); 


Echo ' <Img Src ="hellojlu.png" >'; ?> 


// 输出 图 片 


运行 此 程序 前 应 确认 当前 操作 目录 下 已 经 存在 Logo. png 文件 ,才能 将 LOGO 加 入 到 
二 维 码 中 ,程序 运行 结果 在 浏览 器 中 显示 结果 ,如 图 9-9 所 示 。 

二 维 码 有 一 定 的 容错 性 ,即使 谈 住 某 部 分 仍然 能 够 解码 。 扫 描 二 维 码 时 ,通常 扫描 进 
行 不 到 一 半 时 就 能 解码 ,因为 生成 器 会 将 部 分 信息 重复 表示 以 便 提 高 容错 度 , 这 也 是 在 二 


维 码 中 间 加 个 Logo 图 片 并 不 影响 解码 结果 的 原因 。 


9.9 PHP 程序 出 错 处 理 po 


在 PHP 中 ,系统 默认 的 错误 处 理 方式 
非常 简单 : 当 程序 发 生 错 误 时 ,将 在 浏览 
器 中 显示 一 条 信息 ,这 条 信息 带 有 文件 名 、 
行 号 以 及 出 错 消息 。 类 似 错误 的 发 生 不 但 
使 得 程序 显得 不 专业 ,也 会 使 系统 存在 潜 
在 的 风险 。 


9.9.1 简单 的 错误 处 理 


下 面 程序 试图 打开 一 个 文件 : 





图 9-9 带 有 Logo 的 二 维 码 
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<?PHP $File Fopen ("Exanmple.txt","r"); ?> 
当 系 统 无 法 正常 打开 文件 时 ,浏览 器 利用 默认 的 出 错 处 理 程序 显示 如 下 消息 : 


Warning: Fopen (Fxample.txt) [Function. Fopen]: failed to open stream: No such file or 

directory in C: AppServ \www \index .php on line 2 

在 设计 程序 时 ,通常 要 对 运行 程序 时 可 能 出 现 的 错误 进行 预 判 。 当 真实 出 现 错误 时 ， 
要 调用 Die 函数 提示 用 户 ,并 结束 当前 程序 的 运行 。 

函数 格式 : 

Die (字符 串 ) 

Die( ) 函数 是 Exit( ) 苑 数 的 别名 ,主要 作用 是 输出 一 条 信息 ,并 退出 当前 页 面 脚本 的 
运行 。 其 中 参数 是 一 个 字符 串 ,表示 结束 程序 前 输出 的 内 容 。 

【 例 9.37】 打开 文件 简单 错误 处 理 示例 。 


<?PHP If(!File Fxists("welcome.txt")) 


Die ("文件 不 存在 !"); // 提示 用 户 : 文件 不 存在 ! 并 结束 程序 的 运行 
全 ile 地 open ("welcome.txt","r"); ?> 
显然 例题 9. 37 中 的 代码 更 严谨 ,这 是 由 于 它 采 用 了 错误 处 理 机 制 ,在 错误 出 现 之 后 
终止 了 脚本 。 


9.9.2 用户 自 定 义 错误 处 理 


简单 地 终止 脚本 并 不 总 是 恰当 的 方式 ,用 户 可 以 创建 错误 处 理 的 自 定义 专用 函数 , 当 
发 生 错 误 时 调用 函数 处 理 错 误 信息 。 

通过 使 用 Set_Error_Handler( ) 函数 ,用 户 可 以 使 用 自 定义 的 错误 处 理 函数 处 理 代码 
中 的 任何 错误 。 

函数 格式 : 

Set_Error Handler(" 自 定义 错误 处 理 函 数 ") 

用 户 自 定义 的 函数 ,必须 有 能 力 处 理 至 少 两 个 参数 (Error Level 和 Error Message) ,最 
多 可 以 接受 五 个 参数 ( 可 选项 : Error_File,Error_Line 和 Error_Context) 。 

函数 格式 : 


Error Function (Error Level,Error Message,Error File, 
Error Line,Error Context) 


其 中 Error_Function 是 用 户 自 定义 函数 名 ,函数 每 个 参数 的 含义 如 表 9-5 所 示 。 
表 9-5 用 户 自 定义 错误 处 理 函 数 参 数 的 含义 
参数 含义 描述 
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必 选 。 为 用 户 定义 的 错误 规定 错误 报告 级 别 。 必 须 是 一 个 数值 


rm ev 参见 表 9.6 中 的 错误 级 别 与 错误 描述 





Error_Message 必 选 。 为 用 户 定义 的 错误 规定 错误 消息 











Error_File 可 选 。 规 定 错误 在 其 中 发 生 的 文件 名 
Error_Line 可 选 。 规 定 错误 发 生 的 行 号 
Error_Context 可 选 。 规定 一 个 数组 ,包含 了 当 错 误 发 生 时 在 用 的 每 个 变量 以 及 它们 的 值 





错误 报告 级 别 是 指 错误 处 理 程序 将 错误 划分 为 不 同 的 类 型 ,具体 的 错误 类 型 描述 如 
表 9-6 所 示 。 
表 96 错误 级 别 与 错误 描述 








值 常量 描述 
2 E_WARNINGC 非 致命 的 Run-Time 错误 。 不 暂停 脚本 执行 
Run-Time 通知 。 脚 本 发 现 可 能 有 错误 发 生 , 但 也 可 能 在 脚 


8 |E_NOTICE ps 
本 正常 运行 时 发 生 





致命 的 用 户 生 成 的 错误 。 这 类 似 于 程序 员 使 用 PHP 函数 


»_USER_E > 
2 BUSERAERROR Trigger_Error( ) 设置 的 E_ERROR 





非 致命 的 用 户 生 成 的 警告 。 这 类 似 于 程序 员 使 用 PHP 也 


_USE G 
2 | BUSERSWARNIN 数 Trigger_Error( ) 设置 的 E_WARNING 





用 户 生 成 的 通知 。 这 类 似 于 程序 员 使 用 PHP 函数 Trigger_ 


1024 | E_USER_NOTICE Error( ) 设置 的 E_NOTICE 





可 捕获 的 致命 错误 。 类 似 E_ERROR ,但 可 被 用 户 定义 的 处 


WERAR FERROR 理 程序 捕获 。( 参见 Set_Error_Handler( ) ) 





8191 | E_ALL 所 有 错误 和 警告 , 除 级 别 E_STRICT 以 外 








这 样 就 可 以 设计 一 个 自 定 义 的 错误 处 理 函 数 了 : 
Function Error _ Example ( Sgrrno, $errstr) 
{ Echo "<b Error: </b >[ FErrno] SErrstr br/ >"; 
Echo "发 生 错 误 , 退 出 程序 !"; 
Die(); } 
上 面 的 代码 是 一 个 简单 的 错误 处 理 函 数 。 当 它 被 触发 时 ,会 取得 错误 级 别 和 错误 消 
息 ,然后 会 输出 错误 级 别 和 消息 ,并 终止 脚本 。 拥 有 了 错误 处 理 程序 后 ,用 户 可 以 用 自 定 
义 的 错误 处 理 程序 替换 系统 内 建 的 错误 处 理 程序 。 
【 例 9.38】 用 户 自 定义 错误 处 理 函 数 的 使 用 示例 。 


<2?PHP 
Function CustomError ( SEErrno, SErrstr, SErrfile, Errline) 
{ Echo " 错误 类 型 为 : [ 人 Errno] <br >"; 
Echo“ 错 误 说 明 : S$Errstr <br >"; 
Echo“ 错 误 文 件 : S$Errfile <br >"; 
Echo “错误 行 : Errline <br >"; 
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ky 


die (“发 生 错误 ,退出 程序 !"); } 


a; PDO; 
Set Error Handler ("CustomError"); // 将 CustomError 设 为 默认 错误 处 理 函 数 
Echo ( $a/ 和 ) 7 // 触发 错误 ?> 

程序 输出 结果 为 : 


发 生 错误 ,错误 类 型 为 : [2] 

错误 说 明 : Division by zero 

错误 文件 : C: \AppServ \www Nindex.php 

错误 行 : 13 

发 生 错 误 , 退 出 程序 ! 

根据 在 PHP. INI 中 的 Error_Log 配置 ,PHP 向 服务 器 的 错误 记录 系统 或 文件 发 送出 
错 信息 记录 。 通 过 使 用 Error_Log( ) 函数 ,用 户 可 以 向 指定 的 文件 或 远程 目的 地 发 送出 
错 信息 记录 。 


习 题 


一 、 填 空 题 

1. PHP 提供 了 _ 中 和 ”@@ 两 种 选择 结构 ,如 果 仅 在 两 个 分 支 中 进行 选择 ,通常 
使 用 _@@ 和 @ 语句 在 两 个 分 支 中 进行 选择 。 

2. 循环 结构 中 ,被 反复 执行 的 程序 段 被 称 为 _QD _ ,在 循环 结构 程序 执行 的 过 程 中 ， 
为 了 保证 循环 过 程 能 正常 结束 ,循环 控制 条 件 应 逐步 趋 近 @ 。 

3. 循环 艇 套 是 指 一 个 循环 体 ”包含 在 另 一 个 循环 体内 。 

4._ 循环 结构 只 能 对 数组 进行 操作 。 

5. 在 循环 结构 中 可 以 使 用 Break/Continue 语句 ,其 中 _Q@ 可 以 使 整个 循环 过 程 结 
东 ， @@ 只 是 结束 本 次 循环 ,使 下 一 次 循环 提前 开始 执行 。 

6. 在 PHP 中 ,允许 一 个 数组 中 包含 的 元 素数 据 类 型 QD ,如 果 一 个 数组 中 的 某 个 
元 素 本 身 也 是 一 个 数组 ,这 种 数组 被 称 为 _@® _。 

7. In_Array( ) 函数 和 Array_Search( ) 函数 都 是 在 数组 中 查找 元 素 的 函数 ,其 中 in_ 
aray( ) 函数 的 返回 值 是 _@ ”型 数据 ,而 Array_Search( ) 函数 返回 的 是 元 素 在 数组 中 
的 @ 。 

8. 字符 串 与 字符 数组 的 相互 转换 可 以 通过 QD 函数 和 ”@@ ”函数 来 实现 。 

9. 在 PHP 中 ,函数 可 以 分 为 ”中 ”函数 和 @ 函数 两 大 类 。 

10. 在 调用 的 函数 执行 后 ,一 个 函数 最 多 有 ” _ 个 返回 值 。 

11. 在 调用 函数 时 ,需要 主 调 函 数 向 被 调 函 数 传递 参数 ,参数 的 传递 方式 在 PHP 中 
有 _ 中 传递 和 ”@ 传递 两 种 ,其 中 @) 传递 方式 使 形 参 与 实 参 共用 一 段 内 存 存储 


空间 。 
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12. 在 PHP 中 调用 函数 时 ,如 果 没 有 给 出 相应 参数 的 值 , 系 统 会 在 函数 中 使 用 
”中 “, 没 有 默认 值 的 参数 应 该 定义 在 有 默认 值 的 参数 @ 。 

13. 在 同一 PHP 文件 内 ,如 果 要 在 函数 体内 使 用 全 局 变量 , 则 必须 用 “关键 字 对 
变量 进行 声明 ,将 其 作用 域 扩展 到 函数 体内 。 

14. 静态 变量 的 特点 是 程序 离开 其 作用 域 之 后 ,其 值 _@D ,使 用 静态 变量 必须 使 用 
_ @@ 关键 字 进 行 声明 。 

15. 在 编写 用 户 自 定义 错误 处 理 函 数 时 , 函数 最 少 有 _ 中“ 个 参数 ,它们 分 别 是 

@ 和 @ ，。 

16. 在 使 用 PHP 创建 二 维 码 时 ,需要 用 到 phpqrcode 类 库 的 。” 方法 。 

17. PHP 获取 表单 控件 数据 有 _Q@ 和”@_ 两 种 方法 ,具体 采用 哪 种 方法 ,由 表单 
的 _@ 属性 决定 。 

18. PHP 预定 义 了 Q@ 和 加 两 个 超 全 局 关联 数组 ,分 别 用 于 存储 Post 和 Get 
方法 传送 的 表单 控件 数据 ,元 素 下 标 值 是 表单 控件 的 _@、 属性 值 。 

19. 当 定 义 表单 和 获取 表单 数据 控件 数据 的 程序 存放 在 同一 个 PHP 文件 中 ,定义 表 
单 时 ,Action 属性 值 设 定 为 _Q@ _; 在 程序 中 ,通过 ”@ ”函数 捕捉 用 户 单 击 提交 按钮 或 
图 像 按 钮 的 时 机 ,以 便 执行 PHP 程序 。 

20. 当 定 义 表单 和 获取 表单 数据 控件 数据 的 程序 存放 在 两 个 不 同 的 文件 中 ,定义 表 
单 时 ,Action 属性 值 设 定 为 。 ; 当 用 户 单 击 提交 按钮 或 图 像 按 钮 时 ,执行 对 应 的 PHP 程 
序 文 件 。 

21. 在 获取 表单 控件 数据 时 , 对 于 单 值 控件 可 通过 直接 引用 $_POST[ 控件 名 ] 或 
$ GET[ 控件 名 ] 元 素 的 方式 来 获取 控件 的 _ 中 ”属性 值 ; 对 于 多 值 控件 则 需要 通过 
_@ 的 方式 ,来 引用 数组 中 的 各 个 元 素 。 

22. 在 定义 表单 时 ,如 果 表单 中 包含 文件 域 控件 , 则 表单 的 Enctype 属性 应 设置 为 














23. 在 定义 的 表单 中 ,文件 域 控件 允许 用 户 选 定 _@®_ 个 文件 ,通过 $_POST[ 控件 
名 ] 或 $_GET[ 控 件 名 ] ,可 以 获取 @ 。 

24. 超 全 局 数组 $FILES 是 一 个 _Q@D_ 维 数组 ,第 一 个 下 标 是 _@ ,第 二 个 下 标 
是 ，@ ,，@,，® ,OO 和 oO。 





二 、 单 选 题 
1. 在 PHP 中 每 条 语句 必须 以 ( 。” ”) 符 号 结束 。 

A. 句号 B. 冒号 C. 分 号 D. 中 文 分 号 
2. 在 几 种 循环 结构 中 ,仅仅 能 用 于 数组 的 循环 结构 是 ( )。 

A. While:… B. Do…While C. For D. ForEach 
3. 下 列 代码 将 输出 什么 结果 ? ( ) 。 
<?PHP $i 38; 


If( 人 $++==8) Echo "a"7 
If($--==8) Echo "b"; 
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ElseIf(—--$==8) Echo "c"; 
If(++ 人 ==8) Echo "d"; ?> 


A. bd B. ac C.ad D. be 
4. 在 PHP 的 三 种 基本 循环 结构 中 ,( ) 循环 属于 直到 型 循环 ,循环 体 最 少 要 执行 
一 次 。 
A. For 循环 B. Do…While 循环 C，While 循环 D. ForEach 循环 
5. 在 数字 索引 数组 中 ,系统 默认 情况 下 数组 元 素 的 下 标 从 ( ) 开 始 。 
A. 0 B. 1 C. 任意 值 D. 随机 值 
6. 下 列 函 数 中 ,返回 值 为 逻辑 型 数据 的 函数 是 ( ) 。 
A. In_array() B. Sort() C. Array_Search() D. Implode() 
7. 有 下 面 程序 段 : 


<?PHP $a Array ("a"=>"blue","b"=>"yellow","c"=>"red","d"=>"violet"); 
Echo Array search (“red”, $a); ?> 
程序 输出 的 结果 是 (。 ” )。 
A.a B. b Ce D. d 
8. 下 列 函数 中 ,哪个 函数 可 以 将 一 个 字符 串 按 照 特定 的 分 隔 符 进行 拆 分 ,并 将 拆 分 
的 结果 存 到 一 个 特定 的 数组 中 ( )。 


A. In_Array( ) B. Sort() C. Explode( ) D. Implode( ) 
9. 下 列 函数 中 ,哪个 函数 可 以 将 字符 数组 的 内 容 连接 生成 一 个 字符 串 ( 

A. In_Array( ) B. Sort() C. Explode( ) D. Implode( ) 
三 、 多 选 题 


1. 在 PHP 分 支 结构 程序 设计 中 ,关于 Switch…Case 语句 描述 正确 的 是 (  )。 
. Switch…Case 语句 属于 多 分 支 选择 结构 
B. 每 一 个 Case 后 面 的 语句 组 中 必须 包含 break 语句 
C. 每 一 个 Case 后 面 的 语句 组 中 不 一 定 包含 break 语句 
D. Case 后 面 跟 的 $ Value 必须 是 一 个 常量 
E. 当前 面条 件 都 不 符合 的 时 候 ,系统 执行 Default 后 面 的 语句 
2. 下 面 关于 Break/Continue 语句 的 说 明 ,正确 的 是 ( ye 
A. 它们 都 可 以 结束 本 次 循环 
B. 它们 都 可 以 开始 下 一 次 循环 
C. Break 语句 可 以 出 现在 循环 结构 和 Switch 结构 中 
D. Continue 语句 可 以 出 现在 Switch 分 支 结构 中 用 于 结束 选择 结构 
EContinue 语句 可 以 出 现在 Switch 分 支 结构 的 循环 体内 
3. 根据 PHP 数组 元 素 索引 方式 的 不 同 ,PHP 数组 可 以 分 为 ( 。 ”) 几 种 数组 。 
A. 逻辑 索引 数组 ”B. 数字 索引 数组 ”C. 随机 索引 数组 
D. 关联 数组 E. 顺序 索引 数组 
4. 构成 一 个 PHP 函数 包括 下 面 哪 几 个 部 分 ? 〈 )'s 


pe 
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A. 函数 名 B. 函数 类 型 C. 函数 返回 值 
D. 参数 E. 函数 体 
5. 在 PHP 中 根据 变量 的 作用 域 不 同 ,变量 可 以 分 为 ( ) 种 变量 。 
A. 全 局 变量 B. 静态 变量 C. 动态 变量 
D. 局 部 变量 . 超级 变量 


6. 下 列 关于 retum ter gt 


二 > 


7. 下 


Doom» 


.Returmn 语句 在 函数 体内 只 能 出 现 一 次 
.Return 语句 在 函数 体内 可 以 出 现 多 次 
. Return 语句 可 以 结束 整个 程序 的 运行 
.Return 语句 可 以 结束 函数 的 运行 


.Return 语句 可 以 带 回 多 个 值 作 为 函数 的 返回 值 
列 关 于 PHP 函数 参数 的 说 法 ,正确 的 是 ( )s 
.函数 的 实 参 必须 是 常量 

.函数 调用 时 实 参 必须 有 确定 的 值 

. 使 用 引用 传递 时 , 实 参 必须 是 一 个 变量 

. 函数 的 参数 可 以 有 默认 值 


E， 函 数 调用 时 实 : 参 不 可 以 是 表达 式 
8. 表单 中 属于 单 值 数据 的 控件 有 ( ) 
A. 文本 框 B. 文本 域 C. 复 选 框 组 
D. 列表 E. 密码 框 
9. 下 面 关 于 选择 控件 中 列表 和 菜单 叙述 正确 的 是 ( je 
A. 菜单 属于 单 值 控件 B. 列表 属于 多 值 控件 
C. 菜单 属于 多 值 控件 B. 有 时 可 以 对 列表 进行 多 值 选 择 
E. 列表 和 菜单 都 是 既 属 于 多 值 控件 又 属于 单 值 控件 
10. 下 面 关于 文件 域 叙 述 正确 的 是 ( 入 
A. 使 用 文件 域 即 可 实现 文件 上 传 
B. 通过 文件 域 自身 无 法 实现 文件 上 传 
C. 通过 文件 域 可 以 获取 文件 的 本 地 存储 路 径 
D. 通过 文件 域 可 以 获取 文件 在 服务 器 上 的 存储 路 径 
E. 文件 域 需要 与 超 全 局 数组 $ _FILES 配合 使 用 以 将 文件 上 传 至 服务 器 
四 、 程 序 填空 题 


1. 下 面 程序 输出 100 到 200 之 间 不 能 被 3 整除 的 整数 。 


<?PHP For(S = 中 ; mn<200; ©® ) 


{IE(Ss3=-0 ) 


® 


Echo "Sn br >";} 2> 





2. 下 面 程序 中 定义 了 一 个 3 行 3 列 的 二 维 数组 ,编写 程序 ,计算 对 角 线 上 元 素 的 和 。 


<?PHP 


$= D (Array(l,2,3),Array(4,5,6),Array (7,8,9)); 
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$50; 

FEor(S 07 有 < Si+ 和 
For( 久 性; 和 3; 蘑 + 
{If(® I|® ) 


$5=$5+ 和 [分 ] [人 入]; } 
Echo $5; ?> 


3. 给 出 一 个 正 整数 $x, 要 求 输出 其 逆序 。 例 如 $x 的 值 是 123 , 则 输出 321 。 
< 上 orm Action ="" Method ="Post" > 
<Input Type ="Text" Name ="sz" /> 
<Input Type "Submit" Name ="tj" Value 一 "提交" / ></Form > 
<PHP IE ( D ($POST['tj"])) 
{ x=$ POST["sz"]; 
If($x>300 && $x<=999) 
While( @ ) 
{ n= 加 ; 
Echo Sn; 
$x Floor ( $x/10); } 


Else Echo "数据 输入 错误 "; } ?> 


4. 下 面 程序 对 一 个 一 维 数组 用 选择 排序 法 进行 排序 ,完成 下 面 程序 。 
QPHP $aArray(5,1,16,25,9,33); 
For(Si -0 @ ;Si+H 
{ For( 昼 = 得; 昼 <67 +) 
t IE(@ ) 
{t=@®@ ; 
分 [ 人 条 ] = 名 [ 入]; 
[9] =t; } }} 


ForEach ( Sa as $y) Echo "Sr br>"; ?> 


5. 下 面 程序 利用 静态 变量 来 输出 1 到 10 之 间 所 有 数 的 阶乘 ,完成 下 面 程序 。 
<?PHP 
Function Fac ( $n) 
{_@ $44; 
S$E=$f 4 Sn; 
Return $f; } 
For( 条 习 ; 休 <40; @ ) 
{ Echo 图 ; 


Eho "<r>;} ?> 
6. 下 面 程序 利用 表单 中 的 复 选 按钮 判断 选中 的 个 人 爱好 中 是 否 包含 旅游 ,完成 下 面 
程序 。 


<HIML ><Head > 


<Meta HTTP Fiquiv ="Content -Type" Content ="Text/HIML; Charset utf -8" /> 
<Title > 选择 爱好 </Title ></Head >Body > 
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< 上 orm Action =" Method ="Post" Name ~"forml™" <p> 
<Input Type ="Checkbox" Name 2"ah" Value 2"1" / 尊 育 BR> 
<Input Type ="Checkbox" Name 2"ah" Value 2"2" / 清 乐 BR> 
<Input Type ="'Checkbox" Name 2"ah" Value 2"3" / 3 社交 <BR> 
<Input Type "Checkbox" Name "ah" Value "4" / 汶 游 BR> 
<Input Type ="Checkbox" Name 2"ah" Value ="5" / 浇 曲 <BR> 
<Input Type "submit" Name "Button" Value 二 提交 "><BR></P> 
</Fom> 
<2PHP 
If (Isset($ POST['Button'])) 
{ 处 地 alse; 
For( 信 -0; 估 < 四 (0$ POST['ah'])7 入 + 
{ If($ PosT['ah'][ ©® ]==4) 


{ ttrue; @ ;} 





} 
IE( $t) Echo "包含 旅游 !"; Else Echo "不 包含 旅游 "; 
} 
?></Body > /HIML > 


7. 下 面 程序 将 文件 上 传 至 服务 器 ,并 输出 文件 的 相关 信息 ,完善 程序 。 


<HIML ><Head > 
<Meta HTTP Equiv ="Content -Type" Content ="Text/HIML; Charset utf -8" /> 
<Title > 文件 上 传 </Title ></Head ><Body > 
<Form Action ="" Method ="Post" Enctype ="multipart/form -data" Name ="forml" > 
<Input Type ="'File" Name 2"wj" /> 
<Input Type ="'Submit" Name "tj" Value -="' 提 交 " / ></Fom> 
<?PHP 
If(Isset ($ POST["tj"])) 
{ If($ FILES["wi"]["error"] > 四 ) 
Echo "文件 上 传 发 生 错 误 "; 
Else{ 
Move Uploaded File($ FIIES["wi"]{[" 加 "],"img\\".$ FILES["wi"] ["name"]); 
Echo "文件 上 传 成 功 ! <br >"; 
Echo "文件 大 小 为 : "，$ FILES["wj"] ["size"]," <br >"; 
Echo "文件 类 型 为 : ",$ FILES["wj"][" @ "],"<br>";} 
}?></Body ></HIML > 





五 、 程 序 运 行 结果 填空 
1. 下 面 程序 输出 的 结果 是 中 、@@ 和 @ 。 


<?PHP 和 代 -0; $y D0; $a0; 
While (和 红 < 怀 5) 
{ 钉 = 钉 起 ; 俯 = 儿 +$y; 思 = 思 甘 ? } 
Echo " $x, $y, $z"; ?2> 
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2. 下 列 程序 输出 的 结果 是 四 、@@ 和 @ 。 


<?PHP nn; $5; 
While (True) 
{ $n=nmH; 知 = 知 + 知 ; 
I ($n 38) Break; 
Echo " $5, Hr»>;} ?> 


3. 下 列 程序 输出 的 结果 是 _ 中。 


QPHP $3; MA; Mn; 
While( 知 < 滞 ) 
{ $=$5+Mm+n; MS; 
While( mn) 
{ $=$s+Mm+in; m=An1;} 
m= 和 Mm 二 ; } 
Echo $s; ?> 


4. 下 列 程序 输出 的 三 行 结果 是 四 、@ 和 @ 。 


<?PHP $a Array(3,11,9); 
Echo Array_Search (11, $a)," br >"; 
Echo In Array (9, $a)," dr»>"; 
Sort ( $a, SORT_STRING) ; 
ForEach( $a Rs Salue) Echo Walue; ?> 


5. 下 列 程序 输出 的 结果 是 中 、@ 和 @ 。 


<?PHP $A0; PA5; 
Function Exa (& $n) 
{ Global $a; 
Echo " Sa br>"; n=inH; Echo " $n dor >"; } 
Exa( $b); Echo "$b <br>"; ?> 


6. 在 输入 身份 证 号 22010419900911801X ,并 在 选项 组 中 选择 了 “学 士 ” , 单 击 “ 提 交 ” 
按钮 后 ,下 面 程序 的 输出 结果 是 D 、@ 和 加 。 


<HIML ><Head > 
<Meta HTTP Equiv ="Content -Type" Content ="Text/HIML; Charset autf -8" /> 
<Title > 选择 爱好 </Title ></Head > Body > 
<Eorm Action ="" Method ="Post" > 
身份 证 号 : <Input Type ="Text" Name "sfz"/><P> 
<Input Type ="radio" Name ="xw" Value = 学 士 " Checked / 六 十 BR> 
<Input Type "Radio" Name "xw" Value > 硕士 " / 颈 士 BR> 
<Input Type =Radion Name "xw" Value 博士" / 姜 士 BR> 
<Input Type =Submit" Name ~"Button" Value ~" 提 交 " / ><BR ></P></Form> 
<2PHP 
If(Isset ($ POST["Button"])) 
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{ $sfz=$ POST["sfz"]; $sfz-Trim(RTrim( Ssfz))7 
$xb =Substr ( $sf2z,16,1); $sr Date('Y m-d'",StrtoTime (Substr ( $sfz,6,8))); 
Sxw =$ POST["xw"]; 
Echo " $xb <br > $sr br > $xw br >"; }?> 
</Body > /HIML > 


六 、 程序 设计 题 

1. 求 100 到 999 之 间 的 全 部 水 仙 花 数 。 所 谓 “ 水 仙 花 数 ” ,是 指 一 个 三 位 整数 ,其 各 
位 数 的 立方 和 等 于 该 数 自身 ,如 371 =3” +7 +1。 

2. 给 出 一 个 百分制 成 绩 ,输出 成 绩 等 级 A .BC.D 和 下 。90 分 以 上 为 A,80 ~ 89 为 
B,70 ~79 为 C,60 ~69 为 D,60 分 以 下 为 下 ,要 求 用 Elself 结构 实现 。 

3. 给 出 两 个 正 整数 m 和 n, 求 其 最 大 公约 数 和 最 小 公 倍数 。 

4. 编写 一 个 判断 素数 的 函数 ,在 主 函 数 中 给 出 一 个 正 整数 ,通过 调用 函数 返回 值 判 


1. PHP 中 给 出 的 几 种 循环 结构 有 什么 相同 点 与 不 同 点 ,它们 都 适合 在 什么 时 候 
使 用 ? 

2. Break 和 Continue 都 可 以 用 来 结束 循环 ,它们 结束 循环 的 方式 有 什么 不 同 ? 在 循 
环 体 中 是 否 必须 在 分 支 结构 中 使 用 它们 ? 除了 结束 循环 ,是 否 可 以 在 其 他 地 方 使 用 它们 ? 

3. 在 函数 调用 时 ,一 个 函数 只 能 有 一 个 返回 值 ,是 否 可 以 通过 一 次 函数 调用 得 到 多 
个 变化 的 值 ? 

4. Return 语句 的 作用 是 什么 ? 在 一 个 函数 体 中 是 否 可 以 有 多 条 Return 语句 ,在 一 次 
函数 的 调用 过 程 中 ,是 否 可 以 多 次 执行 Return 语句 ? 
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动态 网 页 及 程序 设计 


Web 应 用 程序 是 一 组 运行 在 网 站 上 的 静态 网 页 和 动态 网 页 的 集合 。 用 户 访问 网 页 
时 ,Web 服务 器 直接 将 静态 网 页 发 送 到 客户 端 浏 览 器 ,而 动态 网 页 需 要 服务 器 运行 程序 ， 
生成 相关 的 静态 网 页 信息 后 再 发 送 到 客户 端 浏览 器 。 图 10-1 展示 了 浏览 器 访问 数据 库 
服务 器 资源 的 动态 网 页 的 运行 过 程 。 








pe 





















































Web 服 务 器 
一 一 一 <HTML> -一 一 一 
响应 <p> 数 据 [= 记录 集 
</HTML> 
应 用 程序 
No 数据 库 
Web 浏 览 器 
<HTML> 
请 求 < 代码 > “ 广 一 | 查询 
</HTML> Oe 
N 


图 10-1 浏览 器 访问 数据 库 的 工作 过 程 


开始 构建 动态 网 页 前 ,必须 做 一 些 准 备 工作 ,包括 设置 Web 应 用 程序 服务 器 ,实现 与 
数据 库 的 连接 等 。 在 网 页 应 用 程序 的 设计 过 程 中 要 考虑 如 何 访问 数据 库 , 并 将 处 理 结果 
返回 并 显示 到 页 面 中 。 在 这 一 过 程 中 主要 解决 如 下 问题 : 

(1) 通过 网 页 登录 和 连接 数据 库 ,如何 设计 网 页 应 用 程序 与 数据 库 的 接口 ? 

(2) 使 客户 能 增加 、 更 新 和 删除 数据 库 中 的 数据 ,如 何 设计 操纵 数据 库 的 应 用 
程序 ? 

(3) 在 网 页 浏览 器 中 能 输出 数据 及 统计 分 析 结 果 , 如 何 设计 输出 数据 的 动态 网 页 
程序 ? 





10.1 网 页 与 数据 库 服务 器 的 连接 


在 网 页 访问 数据 库 之 前 ,网 络 应 用 程序 与 服务 器 及 数据 库 必须 进行 连接 。 在 设计 
PHP 程序 时 ,通过 调用 相关 函数 实现 服务 器 的 连接 和 数据 库 的 选择 。 


10.1.1 连接 数据 库 服务 器 


1. 连接 数据 库 服务 器 的 向 导 


通过 Dreamweaver 操作 (向 导 ) ,可 以 生成 连接 数据 库 服务 器 的 PHP 程序 代码 。 

【 例 10.1】 以 用 户 ywy( 密码 ywy211 ) 身份 连接 数据 库 服务 器 ,代码 存 于 Link. PHP 
文件 中 。 

(1) 启动 Dreamweaver, 在 文件 面板 中 选择 “RCZP" 为 当前 站 点 。 

(2) 新 建 一 个 PHP 文件 ,如 GWCJB. PHP ,并 保存 文件 。 

(3) 在 “数据 库 ” 面板 中 , 单 击 * + "一 “MySQL 连接 "选项 , 按 图 10-2 所 示 设 置 连接 名 
称 ( 如 Link ,也 为 程序 文件 主 名 ) 、MySQL 服务 器 (如 LocalHost) 用户 名 、 密 码 和 数据 库 
(如 RCZP) , 单 击 * 测 试 ?按钮 , 当 显示 ”成 功 创建 连接 脚本 "后 ,再 单 击 “ 确 定 " 按 钮 。 










MYSQL 连 庄 和 和光 和 和 


es 
连接 名 称 : ik [| 
Ca 


A 





登录 数据 库 服 务 器 Ne 
的 用 户 名 和 密码 由 | 时 eceos | 
帮助 





要 连接 的 数据 库 














图 10-2 设置 MySQL 连接 
(4) 保存 文件 GWCJB. PHP。 
2. 连接 数据 库 服 务 器 的 程序 代码 


人 rs 
建立 数据 库 服务 器 连接 后 ,在 当前 站 点 文 [RJG1S 人 名 加 | 加 
件 夹 下 ,产生 了 Connections 文件 夹 和 文件 主 名 < 
为 连接 名 ( Link ) 的 PHP 程序 代码 文件 (如 自动 生成 
Link. PHP) ,如 图 10-3 所 示 。 半天 及 次 件 
其 中 Link. PHP 为 系统 生成 的 连接 数据 库 
服务 器 程序 代码 : 
<?2PHP 
Shostname Link ="LocalHost"; 
$database Link ="rczp"; 














图 10-3 ”Connections 文件 夹 
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Susername Link ="ywy"; 
Spassword Link ="ywy211"; 
SLink MySQL Pconnect ( Shostname Link, $username Link，Spassword Link) Or 
Trigger Error (MySQL Error(),E USER FRROR); ?> 
其 中 MySQL_Pconnect 是 连接 数据 库 服务 器 的 函数 ,3 个 参数 依次 是 数据 库 服务 器 主 
机 名 ,用户 名 和 密码 。 当 连接 数据 库 服务 器 失败 时 ,调用 Trigger_Error 函数 ,显示 出 错 信 
息 ,并 终止 执行 程序 。 本 程序 可 以 简化 为 下 列 一 条 语句 : 
SLink -MySQL Pconnect ("LocalHost", "ywy", "ywy211") Or 
Trigger Error (MySQL Error (),E USER FRROR); 


10.1.2 连接 数据 库 服务 器 的 函数 和 语句 


在 设计 操作 数据 库 的 动态 网 页 程序 时 ,除了 要 连接 数据 库 服 务 器 外 ,还 要 选择 数据 
库 , 设 置 连 接 字 符 集 .提交 SQL 语句 , 断 开 与 数据 库 服务 器 的 连接 等 ,这 些 任 务 都 需要 用 
PHP 函数 或 语句 进行 设计 。 

1. 数据 库 服务 器 的 临时 连接 

函数 格式 ， 

MySQL Connect ( [服务 器 名 ] [, 用 户 名 ] [, 密 码 ]) 

函数 功能 是 建立 PHP 程序 与 数据 库 服务 器 的 临时 连接 。 如 果 连 接 成 功 , 则 返回 临时 
连接 标识 ,否则 返回 False。 函 数 所 在 的 PHP 程序 文件 运行 结束 时 ,自动 断 开 与 数据 库 服 
务 器 的 连接 。 函 数 各 个 参数 的 含义 如 表 10-1 所 示 。 例如, $ TL = MySQL_Connect(" 
LocalHost" , "ywy" , "ywy211" ) 。 


表 10-1 MySQL_Connect 函数 的 参数 说 明 











参数 说 明 
服务 器 名 要 连接 的 服务 器 名 。 默 认 是 LocalHost:3306 
用 户 名 连接 的 用 户 名 。 默 认 是 root 
密码 用 户 密码 。 默 认 是 "" ,表示 无 密码 





2. 临时 连接 的 断 开 
函数 格式 : 
MySQL Close (连接 标识 ) 


函数 功能 是 断 开 与 数据 库 服务 器 的 临时 连接 ,连接 标识 是 调用 MySQL_Connect 函数 
成 功 后 的 返回 值 ,用 于 说 明 要 断 开 的 临时 连接 。 函 数 执行 成 功 ,返回 True, 和 否则 返回 
False。 例 如 ,MySQL_Close( $ TL)。 
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3. 数据 库 服务 器 的 持久 连接 

函数 格式 : 

MySQL Pconnect ([ < 服务 器 名 >] [, < 用 户 名 习 [ 人 黎 码 习 ) 

MySQL_Pconnect 函数 建立 或 打开 一 个 数据 库 服务 器 的 持久 连接 。 函 数 返 回 值 为 连 
接 标 识 符 , 其 中 各 个 参数 的 含义 和 作用 与 MySQL_Connect 函数 相同 。 例 如 , $ Link = 
MySQL_Pconnect ("LocalHost" ,"ywy" ,"ywy211" ) 。 

与 MySQL_Connect 比较 ,该 函数 的 主要 特点 在 于 : 

(1) 先 尝试 寻找 同一 个 持久 连接 (服务 器 名 、 用 户 名 和 密码 均 相 同 ) ,如 果 找 到 , 则 返 
回 此 连接 标识 ;如 果 没 找到 , 则 建立 新 连接 。 

(2) 当 脚 本 执行 结束 后 ,不断 开 持久 连接 ,以 备 以 后 使 用 。MySQL_Close 也 不 能 断 开 
持久 连接 。 


4. 选择 当前 数据 库 
函数 格式 : 
MySQL_Select_DB (数据 库 名 [, 连 接 标识 ]) 


连接 到 数据 库 服务 器 后 ,还 需要 调用 该 函数 选择 当前 数据 库 。 如 果 调 用 该 函数 成 功 ， 
则 返回 True。 如 果 失 败 , 则 返回 False。 函 数 各 个 参数 的 含义 如 表 10-2 所 示 。 例 如 ， 
MySQL_SelecL DB("RCZP" , $ Link), 


表 10-2 MySQL_Select_DB 函数 的 参数 说 明 











参数 说 明 
数据 库 名 要 选择 的 数据 库 名 
连接 标识 规定 MySQL 连接 。 如 果 未 指定 , 则 使 用 最 近 创 建 的 连接 





5. 发 送 语句 
函数 格式 : 
MySQL Query (MySQL 语句 [, 连 接 标识 ]) 
函数 各 个 参数 的 含义 如 表 10-3 所 示 。 
表 10-3 MySQL_Query 函数 的 参数 说 明 








参数 说 明 
MySQL 语句 要 发 送 的 MySQL 语句 字符 串 
连接 标识 连接 标识 符 。 如 果 未 规定 , 则 使 用 最 近 创建 的 连接 





在 PHP 程序 中 ,不 能 直接 执行 MySQL 语句 ,要 操作 数据 库 ,必须 调用 MySQL_Query 函 


第 10 章 动态 网 页 及 程序 设计 


PN 


《5 


数 将 MySQL 语句 作为 字符 串 发 送 给 数据 库 服务 器 ,由 服务 器 执行 MySQL 语句 ,然后 再 将 
执行 结果 返回 给 PHP 程序 ,由 PHP 程序 进一步 生成 静态 网 页 反馈 给 客户 端 浏览 器 。 

MySQL_Query 函数 能 向 服务 器 发 送 语句 字符 串 ,通常 发 送 的 MySQL 语句 有 Insert、 
Update ,Delete 或 Select。 如 果 发 送 Select 语句 成 功 , 则 函数 返回 记录 和 集 标识 符 ; 如 果 发 送 
其 他 MySQL 语句 成 功 , 则 函数 返回 逻辑 值 True。 无 论 发 送 哪 种 语句 ,如 果 执 行 函数 失败 
(可 能 的 原因 : MySQL 语句 有 错误 ,超越 权限 .字符 集 不 配套 和 数据 操作 不 正确 等 ) , 则 函 
数 的 返回 值 都 为 False。 例 如 , $rs_gwcj = MySQL_Query(" Select * From gwcjb" ， 
$ Link ) 。 


6. 设置 字符 集 语 句 


计算 机 网 络 以 B/S 模式 处 理 数据 的 各 阶段 ,都 需要 设置 配套 的 信息 处 理 字符 集 规则 
(如 图 10-4 所 示 ) ,否则 ,可 能 带 来 传输 和 浏览 信息 乱码 ,发 送 MySQL 语句 出 错 等 问题 。 


传输 字符 集 

客户 并 SQL 语句 服务 器 让 

字符 集 性 字符 集 
传输 字符 集 


返回 结果 
图 104 B/S 模式 处 理 数据 的 各 阶段 字符 集 示意 图 








(1) 客户 端 字 符 集 。 在 每 个 网 页 文件 的 <Head > 和 </Head > 之 间 , 通 常 加 < Meta 
HTTP-Equiv = "Content-Type" Content =" TexVHTML; CharSet = 字符 集 名 称 "/ > 标签， 
说 明 客 户 端 浏览 器 的 字符 集 , 解 决 浏览 信息 乱码 问题 。 

(2) 服务 器 端 字符 集 。 通 常 在 文件 my. ini 中 用 “Character_Set_Server = 字符 集 名 称 ” 
选项 ,或 者 ,创建 数据 库 时 选择 字符 集 名 称 ,进行 配置 服务 器 端 存 储 和 处 理 信息 的 字符 集 。 

(3) 传输 信息 字符 集 。 在 连接 数据 库 服务 器 之 后 ,发 送 MySQL 语句 之 前 ,向 服务 器 
发 送 “Set Names 字符 集 名 称 " 语 句 字 符 串 ,设置 发 送 MySQL 语句 和 接收 返回 结果 的 传输 
信息 字符 集 。 例 如 ,MySQL_Query("Set Names ' UTF-8'" ) 。 

适合 于 汉字 的 常用 字符 集 名 称 如 表 104 所 示 。 

表 104 常用 字符 集 名 称 

字符 集 名 称 适用 语言 范围 
GBK 汉字 内 码 扩展 规范 ,是 对 GB2312 的 扩展 ,支持 简体 中 文 及 繁体 中 文 
GB2312 信息 交换 用 汉字 编码 字符 集 , 支 持 简体 中 文 


对 Unicode 的 可 变 长 度 字符 编码 ,又 称 万 国友 ,支持 简体 中 文 繁体 中 文 及 其 他 语言 
(如 英文 .日 文 ,韩文 ) 


Big5 大 五 码 ,支持 繁体 中 文 











UTF-8 








7. 返回 错误 文本 
函数 格式 : 
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MySQL Error (标识 符 ) 

MySQL_Error 返回 调用 有 关 MySQL 函数 时 产生 的 出 错 信息 ,如 果 没 有 出 错 , 则 返 
回 ""( 空 字符 串 ) 。 

在 设计 PHP 程序 时 ,为 了 避免 程序 运行 出 错 ,在 调用 MySQL_Connect MySQL_Close、 
MySQL_Pconnect .MySQL_Select_DB 或 MySQL_Query 函数 后 ,都 要 进行 分 析 判 断 ,以 便 决 
定 是 否 要 继续 执行 下 一 步 。 

【 例 10.2】 以 用 户 ywy (密码 ywy211 ) 身份 连接 数据 库 服 务 器 ,并 发 送 Select * 
From gwcjb 语句 。 

<HIML ><Head > 

<Meta HTTP Equiv ="Content -Type" Content ="Text/HIML; CharSet =UTF -8" /> 

<Title > 连接 服务 器 发 送 SQL 语句 </Title ></Head > 

<Body > 

<?PHP $Link -MySQL Connect ("LocalHost", "ywy", "ywy211"); 

IE (! $Link) Die (MySQL Error()); // 连接 数据 库 服 务 器 失败 ,输出 错误 信息 ,退出 程序 
If£(!MySQL Select DB ("RCZP"，$Link)) Die (MySQL Error()); ”// 选择 数据 库 失 败 ,退出 程序 
MySQL Query ("Set Names 'uft -8'"); ”// 发 送 字符 集 语句 

Srs gwcj MySQL Query ("Select * From gwcjb", $Link);  // 发 送 SQL 语 扣 

If (! Srs gwcj) Die (MySQL Error()); // 发 送 SQL 语 句 失败 ,不 执行 下 面 的 程序 代码 


Echo "一 切 准备 就 绪 !"; // 此 处 可 以 编写 处 理 记录 集中 数据 的 代码 
MYSQL Close ( SLink) 7 // 断 开 与 数据 库 服 务 器 的 连接 ?> 
</Body > </HIML > 


运行 程序 时 ,如 果 函 数 MySQL_Connect(" LocalHost" ,"ywy" ,"ywy211" ) 中 的 用 户 密 
码 ywy211 不 正确 , 则 程序 运行 出 错 信息 ,如 图 10-5 所 示 。 





Warning: nyysql_connect0: Access denied for user 
MySQL_Error ‘ywy'@'localhost (using password: YES) im 
函数 的 返回 值 E:MYSQL Dwxampp htdocsrczp LKSERVER.php on line 6 
Access denied for user YWYQlocalhost (using password: YES) 

















图 10-5 ”程序 运行 出 错 信息 


10.2 发 送 SQL 语句 的 向 导 


PHP 程序 不 能 直接 访问 数据 库 管理 系统 ,必须 向 服务 器 发 送 MySQL 语句 ,通过 服务 
器 运行 MySQL 语句 后 返回 结果 (也 称 记 录 集 ) , 间接 处 理 数据 库 中 的 数据 。 因 此 ,记录 集 
是 PHP 程序 与 MySQL 数据 库 管 理 系统 之 间 的 桥梁 。 
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10.2.1 发 送 简 单 Select 语句 的 向 导 


在 Dreamweaver 中 打开 PHP 程序 文件 后 ,通过 创建 记录 集 ( 查 询 ) 的 向 导 方 法 ,可 以 
生成 向 服务 器 发 送 的 Select 语句 和 接收 服务 器 返回 结果 的 PHP 程序 代码 。 

【 例 10.3】 按 笔试 成 绩 由 高 到 低 从 GWCJB 中 提取 岗位 编号 B0002 的 有 关 数据 ,将 
满足 要 求 的 Select 语句 发 送 到 服务 器 ,并 接收 处 理 结果 ,测试 结果 如 图 10-6 所 示 。 


OH 































记录 身份 证 号 岗位 编号 资格 审核 笔试 成 绩 面试 成 绩 
1 11980119921001132X B0002 1 90 85 
2 229901199503121538 B0002 1 90 85 
3 219901199001011351 B0002 1 89 88 
4 229901199305011575 B0002 0 75 5 
[前 zs 个 &) ] [ 下 zs 个 四 [| 


















图 10-6 记录 集 测试 窗口 


(1) 打开 GWCJB. PHP 文件 ,在 “ 绑 定 "面板 中 , 单 击 * + "一 “记录 集 ( 查询)" 选 项 。 

(2) 在 “记录 集 ” 简 单 对 话 框 中 ,如 图 10-7 所 示 ,设置 记录 集 名 称 (用 户 自 定义 ,如 rs_ 
gwcj ) ,数据 库 服务 器 连接 名 ( 如 Link ) ,数据 表格 名 (如 gwcjb) 、 列 \ 记 录 筛选 条 件 以 及 排 
序 方式 , 单 击 “ 测 试 " 按 钮 , 测试 结果 如 图 10-6 所 示 。 






































| sm me EE 
数据 库 连接 一 全 二 Ee 二 = [gc] | GE 
数据 源 : CE 

_ 必 助 














字段 列表 框 
筛选 条 件 






画 
| 商 位 编号 vj 
葡 和 的 值 =] B0002 
:全 试 成绩 ~] 降序 ~ 

































排序 关键 字 

















图 10-7 “记录 集 " 简 单 对 话 框 


(3) 单 击 “确定 "按钮 ,在 “ 绑 定 ”面板 中 增加 了 “记录 和 集 (rs_gwcj)” 选 项 。 
(4) 在 “代码 "视图 下 ,可 以 查看 和 修改 系统 生成 的 代码 : 


<?PHP Require Once('Connections/Link.PHP'); ?> 
<2PHP 
If (!Function Exists ("GetSQLValueString")) 
{ EEE } 
MySQL Select DB ( $database Link, $Link); 
Sauery rs gwcj ="Select * From gwcjb Where 岗位 编号 ='B0002' Order By 笔试 成 绩 
DESC™; 
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STs gwcj -MySQL Query( $query rs gwcj, $Link) Or Die (MySQL Error()); 
Srow rs gwcj MySQL Fetch Assoc( $rs gwcj); 
S$totalRows rs gwcj MySQL Num Rows (Srs gwcj); ?> 
<HIML xmlns ~"HTTP://www.w3 .org/1999/xhtml" > 
Snes </Html > 
<?PHP MySQL Free Result (Srs gwcj); ?> 


(5) 优化 后 等 效 的 PHP 代码 及 注释 如 下 : 


<?PHP 
Require Once('Connections/Link.PHP'); // 装载 并 执行 例 10.1 生成 的 Link.PHP 
MySQL Select DB( $database Link, $Link); // 选择 当前 数据 库 


// 将 生成 的 Select 语句 字符 串 存 于 变量 $query _rs_gwcj 中 
$query rs gwcj ="Select * From gwcjb Where 岗位 编号 ='B0002' order By 笔试 成 绩 
DESC"; 
// 发 送 SQL 语句 ,并 得 到 记录 集 科 s_gwcj ,出 错时 停止 执行 
Srs gwcj MySQL Query ( $query rs gwcj, $Link) Or Die (MySQL Error()); 
// MySQL Fetch Assoc 函数 获取 记录 集中 的 1 行 数据 , 存 于 关联 数组 row_rs_gwcj， 
// 下 标 分 别 是 Select 语句 中 的 列 名 称 , 如 身份 证 号 和 岗位 编号 等 
Srow rs gwcj -MySQL Fetch Rssoc( Srs gwcj); 
StotalRows rs gwcj -MySQL Num Rows ( Srs gwcj); 
// 记录 集中 的 行 数 存 于 StotalRows rs _gwc]j 
SS 


(6) 要 使 程序 更 简明 、 易 懂 和 引用 ,进一步 简化 代码 如 下 : 

<2PHP $Link MySQL Pconnect ("LocalHost", "ywy", "ywy211"); ”// 连接 数据 库 服 务 器 
MySQL Select DB("RCZP", $Link); // 选择 当前 数据 库 
Ssql ="Select * From gwcjb Where 岗位 编号 ='B0002' Order By 笔试 成 绩 DESC"; 
Srs gwcj MySQL Query( $sql, $Link) Or Die (MySQL Error()); 
Srow gwcj MySQL Fetch Assoc( $rs gwcj); 
StotalRows MySQL Num Rows ( $rs_gwcj); // 记录 集中 的 行 数 存 于 StotalRows ? 
> 


(7) 保存 并 关闭 文件 GWCJB. PHP。 
10.2.2 发 送 与 设计 Select 语句 的 向 导 


在 “记录 集 ” 简 单 对 话 框 中 ,只 能 对 一 个 数据 表 生 成 简单 的 Select 语句 , 单 击 “ 高 级 ” 
按钮 ,在 “记录 集 " 高 级 对 话 框 中 ,如 图 10-8 所 示 , 可 以 设计 较 复 杂 的 Select 语句 ,如 多 个 
表 连 接 数据 分 组 .语句 能 套 和 语句 合并 等 ,甚至 可 以 将 PHPMyAdmin 可 视 化 窗口 中 正常 
运行 的 Select 语句 粘贴 到 SQL 框 中 。 

最 后 单 击 “ 测 试 "及 “确定 ”按钮 ,系统 生成 的 程序 代码 与 例 10. 3 类 似 ,只 是 Select 语 
句 有 些 差 异 。 
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名 区 rs_Cxewcj 
= 二 测试 
= am T 姓名 , 岗位 名 称 , 笔试 成 顷 , 面试 成 绩 
输入 in grclb natural 简单 
> 一 人 excjb. 出所 纺 号 < 000Z 
Select 语 名 et [|] 




































































数据 库 项 - | 田 团 表格 添加 到 SQL 
田 妈 视图 SELECT 

田震 预存 过 程 二 

ORDER BY 








图 10-8 “记录 集 " 高 级 对 话 框 


10.3 数据 查询 动态 网 页 程序 设计 


为 了 使 网 页 浏览 器 能 输出 数据 库 中 的 数据 及 统计 分 析 结 果 ,可 以 依据 Dreamweaver 
向 导 ( 记 录 集 ) 与 PHP 程序 结合 ,设计 输出 数据 的 动态 网 页 程序 。 


10.3.1 输出 记录 集中 的 数据 


通常 将 记录 集 与 表格 相 结合 ,将 数据 库 中 的 数据 转换 成 浏览 器 能 解析 的 表格 ,使 数据 
呈现 在 浏览 器 中 。 


1. 输出 记录 集 部 分 列 的 向 导 


【 例 10.4】 将 文件 GWCJB. PHP 中 记录 集 s_gwei 的 部 分 列 的 全 部 记录 显示 到 网 页 
中 ,效果 如 图 10-9 所 示 。 


加 | 


| 应 聘 人 员 身 份 证 号 ”| 竞聘 岗位 编号 | 笔试 成 绩 | 面试 成 绩 
|11980119921001132X |B0002 90 85 











|219901199001011351 |B0002 89 88 
|229901199305011575 |B0002 75 "3 
|229901199503121538 |B0002 90 85 

















图 10-9 将 记录 集 全 部 记录 的 部 分 列 选择 到 网 页 中 


(1) 打开 文件 GWCJB. PHP ,在 网 页 中 插入 一 个 2 行 4 列 的 表格 ,其 中 第 一 行 输入 表 
格 各 列 标题 文字 (如 应 聘 人 员 身 份 证 号 .竞聘 岗位 编号 .笔试 成 绩 和 面试 成 绩 ) 。 


基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


(2) 在 “ 绑 定 "面板 中 , 单 击 记录 集 rs_gwej 前 的 * + "将 其 展开 ,将 列 名 称 ( 如 身份 证 
号 .岗位 编号 .笔试 成 绩 和 面试 成 绩 ) 拖 动 到 表格 第 二 行 的 对 应 单元 格 中 。 

(3) 按 快捷 键 Cul +S 保存 文件 ,再 按 F12 键 在 浏览 器 中 预览 ,效果 如 图 10-10 所 示 ， 
仅 显 示 了 记录 集中 的 第 一 条 记录 。 





应 聘 人 员 身 份 证 号 ”| 竞聘 岗位 编号 | 笔试 成 绩 
11980119921001132X |B0002 90 

















图 10-10 ”将 记录 集 的 一 个 记录 中 的 某 些 列 选择 到 网 页 中 


(4) 切换 到 “代码 "视图 ,在 <Body > 与 </Body > 标记 中 间 生 成 了 如 下 PHP 代码 : 

<Table Border ="1" Cellpadding ="0" Cellspacing ="4" > 

<IR> ”<! - -表格 的 第 一 行 ,显示 列 标题 文字 --> 

<TD 六 聘 人 员 身 份 证 号 </TD ><TD 洲 聘 岗位 编号 </TD > 
<TD 痢 试 成 绩 </TD ><TD > 面试 成 绩 </TD ></TR > 

<IR> <! -- 表 格 的 第 二 行 ,将 存 于 关联 数组 row_rs_gwcj 中 的 第 一 条 记录 输出 到 表格 --> 

<TD ><?PHP Echo Srow rs _gwcj [" 身 份 证 号 ']; ?></TD> 

<TD ><?PHP Echo $row_rs_gwcj[' 岗 位 编号 ']; ?></TD> 

<TD ><?PHP Echo $row_rs_gwcj[' 笔 试 成 绩 ']; ?></TD> 

<TD ><?PHP Echo $row_rs_gwcj[' 面 试 成 绩 ']; ?></TD> 

</TR ></Table > 

(5) 切换 到 “设计 ”视图 ,选中 表格 的 第 2 行 ,在 “服务 器 行为 "面板 中 , 单 击 ” + ”一 
“重复 区 域 " 选 项 。 

(6) 在 “重复 区 域 "对 话 框 中 ,选择 要 显示 的 记录 集 和 记录 数 (如 所 有 记录 ) , 单 击 “ 确 
定 "按钮 , 按 快捷 键 Cul +S 保存 文件 ,再 按 F12 键 预览 ,效果 如 图 10-9 所 示 。 

从 上 述 设计 过 程 可 以 看 出 ,本 向 导 适 合 输 出 记录 集中 某 些 列 的 数据 , 列 标题 的 文字 可 
以 与 记录 集 ( 实质 为 Select 语句 ) 中 的 列 名 称 不 同 , 特 别 适合 输出 少量 的 数据 项 。 对 于 以 
表格 形式 输出 数据 ,操作 步骤 比较 烦琐 。 

2. 输出 记录 集 全 部 列 的 向 导 

(1) 打开 文件 GWCJB. PHP ,切换 到 “设计 ”视图 , 单 击 * 插 入 "菜单 一 “动态 对 象 "一 
“动态 数据 "一 “动态 表格 "选项 。 

(2) 在 “动态 表格 "对话 框 中 ,设置 要 显示 的 记录 集 、 需 要 显示 的 记录 数 ( 如 所 有 记 
录 ) 表格 的 边框 .单元 格 边 距 和 单元 格 间距 等 参数 , 单 击 “确定 "按钮 。 

(3) 按 快 捷 键 Cul + S 保存 文件 , 按 Fl12 键 在 浏览 器 中 预览 效果 如 图 10-11 所 示 。 

此 向 导 比 较 适 合 以 表格 形式 输出 记录 集中 的 所 有 列 ,表格 由 系统 自动 生成 ,并 且 表 格 
的 列 标题 与 记录 集中 的 对 应 列 名 称 一 致 ,设计 过 程 比较 简单 。 

3. 向 导 生 成 的 程序 代码 

通过 向 导 设计 显示 记录 集中 数据 的 表格 后 ,在 文件 CGWCJB. PHP 中 系统 生成 的 核心 
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代码 与 下 列 代码 类 似 : 


<Table Border ="1" Cellpadding ="2" Cellspacing 2"'0" > 
<IR> <!-- 表 格 的 第 一 行 ,显示 字段 名 --> 
<TD 将 份 证 号 </TD ><TD 六 位 编号 </TD ><TD 资格 审核 TD > 
<TD 次 试 成 绩 </TD ><TD > 面试 成 绩 </TD ></TR > 
<! - -通过 循环 结构 ,动态 生成 表格 的 其 余 行 ,将 记录 集中 的 所 有 记录 都 输出 到 网 页 中 --> 
<?PHP Do { ?> 
<TR ><! -关联 数组 row_rs_gwcj 中 存放 了 记录 集 rs_gwcj 中 的 一 条 记录 --> 
<TD ><?PHP Echo $row_rs_gwcj[' 身 份 证 号 ']; ?></TD> 
<ID ><?PHP Echo $row_rs_gwcj[' 岗 位 编号 ']; ?></TD> 
<ID ><?PHP Echo $row_rs_gwcj[' 资 格 审 核 ']; ?></TD> 
<ID ><?PHP Echo $row_rs_gwcj[' 笔 试 成 绩 ']; ?></TD> 
<ID ><?PHP Echo $row_rs_gwcj[' 面 试 成 绩 ']; ?></TD ></TR> 
<?PHP } While ( $row rs gwcj -MySQL Fetch Rssoc( Srs gwcj)); ? ></Table > 


其 中 ,每 调用 一 次 MySQL_Fetch_Assoc 函数 ,都 以 关联 数组 的 形式 返回 记录 集 ( rs_ 
gwoj ) 中 新 的 一 行 数据 或 敢 辑 假 False。 


10.3.2 与 记录 集 相 关 的 函数 


1. 获取 记录 集中 的 一 行 存 于 关联 数组 
函数 格式 : 
MySQL Fetch_Assoc (记录 集 标识 符 ) 
参数 “记录 集 标 识 符 "为 MySQL_Query 发 送 Select 语句 时 返回 的 值 。 每 调用 一 次 
MySQL_Fetch_Assoc 函数 都 从 记录 集中 取得 一 行 新 数据 存 于 关联 数组 中 ,数组 元 素 的 键 
(下 标 ) 对 应 记录 集中 的 列 名 , 若 没有 新 数据 行 , 则 返回 False。 
【 例 10.5】 设计 能 输出 如 图 10-11 所 示 的 网 页 程序 PXGWCJ. PHP。 
PXGWCJ. PHP 的 完整 程序 代码 如 下 : 
<2PHP SRCZPLJ =MySQL PConnect ("LocalHost", "ywy", "ywy211"); // 连接 数据 库 服务 器 
MySQL Select db ("RCZP", $RCZPLJ); // 选择 数据 库 
MySQL Query ("Set Names 'UTF -8'"); // 设置 字符 集 


$rs CJB MySQL Query ("Select * From GWCJB Where 岗位 编号 ="'B0002' Order By 笔记 成 绩 
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DESC", $RCZPLJ); // 发 送 Select 语句 ?> 
<HIML ><Head > 


<Meta HTTP 了 qujv ="Content -Type" Content ="Text/HIML; CharSet UTF -8"/ > 
<Title 渝 出 申报 岗位 成 绩 表 </Title ></Head ><Body > 
<Table Border ="2™" > 


<Caption > ”岗位 成 绩 表 </Caption > 


<TR><TD > 汪 份 证 号 <0D 闹 位 编号 <TD 资格 审核 <TD 交 记 成 绩 <TD ;面试 成 绩 <wTR > 
<2PHP 


$row CJB -MySQL Fetch Rssoc (Srs CJB); // 获取 第 一 行 数据 


Do { Echo ' <Tr ><TD >', $row_CJB[' 身 份 证 号 ']; Echo ' <TD >'，Srow_ COB[' 岗 位 
编号 ']; 


Echo ' <ID >'，Srow_COB[ ' 资 格 审核 ']; Echo ' <TD >'，$row_CJB[' 笔 试 成 绩 '] ; 
Echo ' <TD >'，S$row_CJB[' 面 试 成 绩 '],' </Tr >'"; } 
While ( $row CJB MySQL Fetch Assoc( $rs CJB)); 


// 获取 其 他 行 ,直到 最 后 一 行 ?> 
</Table ></Body ></HTML > 
2. 获取 记录 集中 的 一 行 存 于 索引 数组 
函数 格式 : 
MySQL_Fetch_Row (记录 集 标识 符 ) 
函数 的 调用 方法 和 功能 与 MySQL_Fetch_Assoc 类 似 ,差异 仅 在 于 从 记录 集中 获取 的 
新 数据 行 存 于 索引 数组 中 ,数组 元 素 下 标 值 从 0 开始 ,依次 递增 1。 
3. 获取 记录 集中 的 一 行 存 于 数组 
函数 格式 : 
MySQL Fetch_Array (记录 集 标识 符 ) 


函数 具有 MySQL_Fetch_Row 和 MySQL_Fetch_Assoc 的 双重 功能 ,存储 新 数据 行 的 数 
组 可 以 作为 关联 或 索引 数组 引用 。 


【 例 10.6】 设计 能 输出 每 个 岗位 招聘 人 数 .申报 人 数 .笔试 最 高 分 和 平均 分 的 网 页 
程序 GWSBTJ. PHP。 


GWSBTJ. PHP 的 完整 程序 代码 如 下 : 
<?PHP 
SRCZPLJ MySQL PConnect ("LocalHost", "ywy"v "ywy211") ; // 连接 数据 库 服务 器 


MySQL Select db ("RCZP"， SRCZPLJ) ; // 选择 数据 库 
MySQL Query ("Set Names 'UTF -8'") ; // 设置 字符 集 


S$SGWSBTJ =MySQL Query ("Select 岗位 编号 ,岗位 名 称 , 人 数 as 招聘 人 数 ， 
Count (身份 证 号 ) As 申报 人 数 ,Max (笔试 成 绩 ) as 最 高 分 ,AVG (笔试 成 绩 ) Rs 平均 分 
From GWB Natural Join GWCJB Group By 岗位 编号 "，SRCZPLJ) ; // 发 送 Select 语句 ?> 
<HIML ><Head> 


<Meta HTTP Fiquiv ="Content -Type" Content ="Text/HIML; CharSet TF -8"/ > 
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<Title 疯 位 申报 统计 表 </Title ></Head ><Body> 
<Table Border "2"” ><Caption > ”岗位 申报 统计 表 </Caption > 
<Tr ><Th 疯 位 编号 <Ih 疯 位 名 称 <Ih 涛 聘 人 数 
<Th 冲 报 人 数 <Ih 凝 高 分 <Ih 羡 均 分 </tr > 


<?PHP 

Srow MySQL Fetch Array ( SGWSBTJ); // 获取 第 一 行 数据 

Do { Echo ' <Tr ><TD >'， $row[' 岗 位 编号 ']; // 可 引用 元 素 $row[0] 
Echo ' <TD >'，$row[' 岗 位 名 称 ']; // 可 引用 元 素 $row[1] 
Echo ' <TD >'， $row[' 招 聘 人 数 ']; // 可 引用 元 素 $row[2] 
Echo ' <TD >'， $row[' 申 报 人 数 ']; // 可 引用 元 素 $row[3] 
Echo ' <TD >'， $row[' 最 高 分 ']; // 可 引用 元 素 $row[4] 
Echo' <TD >'， $row[' 平 均 分 ']; // 可 引用 元 素 $row[5] } 


While ( $row=ySQL Fetch Array ( SGNSBTJ) ) 7 
// 获取 其 他 行 ?></Table ></Body ></HIML > 


4. 获取 记录 集 的 行 数 

函数 格式 : 

MySQL Num Rows (记录 集 标识 符 ) 

函数 返回 值 为 记录 集中 的 数据 行 数 。 

5. 获取 记录 集 的 列 数 

函数 格式 : 

MySQL Num Fields (记录 集 标识 符 ) 

函数 返回 值 为 记录 集中 的 数据 列 数 ,如 果 失 败 , 则 函数 返回 值 为 False。 

6. 获取 记录 集 的 列 名 

函数 格式 : 

MySQL Field Name (记录 集 标识 符 , 列 号 ) 

函数 返回 值 为 记录 集中 某 列 号 对 应 的 列 名 称 ,0 为 第 一 列 ,1 为 第 二 列 ,……: 。 如 果 函 
数 调用 失败 , 则 返回 值 为 False。 

7. 获取 记录 集中 的 数据 

函数 格式 : 

MySQL Result (记录 集 标识 符 , 行 号 [, 列 名 列 号 ]) 


其 中 “ 行 号 "为 记录 集中 的 行 号 ,从 0 开始 ;“ 列 名 或 列 号 "是 可 选 参数 ,默认 返回 
第 一 个 列 的 值 。 如 果 调用 函数 成 功 , 则 返回 记录 集中 指定 行 和 列 的 数据 ;否则 返回 


False。 
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【 例 10.7】 在 表格 中 显示 2000 年 以 后 注册 的 公司 信息 ,效果 如 图 10-12 所 示 。 





RCZP 数 据 库 的 公司 表 中 注册 日 期 在 2000 年 以 后 的 数据 如 下 : 
共计 3 行 8 列 
注册 日 期 | 注 


|_ 名 各 

访 调 优 稚 店 | 攻 震 经 济 开发 区 |2013-01-0 引 

廊 府 快餐 店 a| 长 春 经 济 开发 区 |2015-10-1s|10 | 

攻读 人 司 | 开 京 币 中 关 和 2001-07-01]4000 | 和 要 天 io0201 | | | 











图 10-12 利用 动态 表格 显示 数据 


在 Dreamweaver 中 新 建 一 个 PHP 网 页 文件 ,如 ShowTable. PHP, 切 换 到 “代码 ”视图 ， 
删除 全 部 代码 ,重新 输入 如 下 代码 后 保存 : 


<?PHP 
Function ShowTable() // 定义 ShowTable 函数 用 于 显示 查询 结果 
{ $Link -MySQL PConnect ("LocalHost", "ywy", "ywy211") Or Die ( MySQL Error() ); 


. 


MySQL Select DB ("RCZP") ; 
MySQL, Query ("Set Names 'UTF -8'"); 
$sql ="Select * From 公司 表 Where 注册 日 期 >='2000 -01 -01'"; 
$result MySQL Query ( $5q1); // 将 查询 语句 发 送 到 数据 库 服务 器 并 返回 记录 集 
Srows MySQL Num Rows ( $result); // 获取 记录 集 的 行 数 
Scolumns MySQL Num Fields ( $result); // 获取 记录 集 的 列 数 
Echo "RCZP 数据 库 的 公司 表 中 注册 日 期 在 2000 年 以 后 的 数据 如 下 : <BR/ >"; 
Echo "共计 ". Srows." 行 ". Scolumns." 列 <BR/ >"; 
Echo " <Table Border ='1px' Cellspacing ='0px' >"; // 定义 表格 
Echo "<TR >"7 // 定义 表格 中 的 第 一 行 
For($i-0; 和 <Scolumns;y 人 +H) 
// 循环 输出 记录 集 的 列 名称 到 表格 的 第 一 行 ( 列 标题 ) 
{ $field Name -MySOL Field Name ( $result, $1); // 获取 记录 集中 第 并列 名 称 
Echo " <TH > Sfield Name <Y/TH>"; ”// 定义 表 的 列 标题 } 
} 
Echo " </TR>"; // 第 一 行 定 义 结束 
// 利用 循环 动态 定义 表格 的 其 余 行 ,显示 记 
录 集 中 的 各 个 记录 
// MySQL _Fetch Row 函数 以 索引 数组 的 形式 
返回 记录 集中 的 一 条 记录 
While ( $row -MySQL Fetch Row( $result)) // 进入 数据 行 循环 
{ Echo "<R>"; 
For(Si -0; 全 <Scolumns;y $++) Echo "<ID>S$row[ $1] </TD>"; 
// 显示 查询 结果 各 列 数据 
Echo " </IR>"; } 
Echo " </Table >"; // 表格 定义 结束 
// 函数 定义 结束 


? ><HIML ><Head ><Meta HITP -Equiv ="Content -Type™ Content ="Text/HIML; CharSet = UTF — 
8"/ ></Head > 
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<Body > < ?PHP ShowTable () 7? ></Body > </HIML > 


10.4 数据 维护 程序 设计 


在 较 完 整 的 网 络 应 用 程序 中 ,需要 设计 数据 维护 方面 的 程序 。 如 岗位 设置 ,应聘 人 员 
注册 .岗位 成 绩 管 理 .公司 注 册 和 论坛 发 表 等 数据 都 需要 维护 。 数 据 维护 需要 为 用 户 提供 
输入 (插入 ) ,修改 (更 新 ) 和 删除 数据 等 交互 性 网 页 。 


10.4.1 设计 插入 数据 的 网 页 程序 


允许 用 户 向 数据 库 中 插入 数据 记录 的 网 页 应 用 程序 应 该 由 两 个 部 分 组 成 : 一 部 分 是 
用 户 输入 数据 的 交互 式 表 单 , 男 一 部 分 是 实现 数据 记录 插入 的 程序 代码 。 
【 例 10.8】 设计 能 向 GWCJB 中 插入 记录 的 网 页 Insert_GWCJB. HTML。 


1. 设计 表单 向 导 


(1) 启动 Dreamweaver, 单 击 PHP 选项 ,新 建 一 个 空白 的 HTML 网 页 。 

(2) 光标 定位 在 < Body > 和 </Body > 之 间 , 单 击 “ 插 入 "菜单 一 “表单 "一 “表单 ” 选 
项 。 在 标签 编辑 对 话 框 中 ,设置 “操作 ”为 CRGWCJB. PHP,“ 方 法 "为 Post, “名 称 ” 为 
Forml ,其 他 项 为 默认 设置 , 单 击 “ 确 定 " 按 钮 。 

(3) 光标 定位 在 < Form > 和 </Form > 之 间 , 输 入 * <P > 身份 证 号 </P >” ,将 光标 
定位 在 " </P > "之 前 , 单 击 “ 插 入 "菜单 一 “表单 "一 “文本 域 "选项 ,在 标签 编辑 对 话 框 
中 ,设置 名称" 为 “身份 证 号 ”( 与 字段 名 相同 ,以 便 设 置 控件 与 字段 关联 时 ,控件 与 字段 
能 够 自动 匹配 ) ,其 他 项 为 默认 设置 , 单 击 “ 确 定 ” 按 钮 。 

(4) 按 第 (3) 步 相同 的 方法 为 GWCJB 中 的 岗位 编号 字段 创建 对 应 的 表单 控件 。 

(5) 输入 * <P > 资格 审核 </P > ”, 将 光标 定位 在 “资格 审核 "之 后 , 单 击 “ 插 入 "菜单 
一 “表单 "一 “ 单 选 按钮 "选项 ,在 标签 编辑 对 话 框 中 ,设置 名称" 为 “资格 审核 ",“ 值 "为 
0, 选 中 “已 选中 "项 , 单 击 “ 确 定 ” 按 钮 。 

(6) 将 光标 定位 在 " </P > "之 前 ,输入 “未 通过 ”, 单 击 “ 插 入 "菜单 一 “表单 "一 “ 单 
选 按 钮 "选项 ,在 标签 编辑 对 话 框 中 ,设置 “名 称 "为 “资格 审核 ”,“ 值 "为 1 ,其 他 项 为 默认 
设置 , 单 击 “ 确 定 " 按 钮 。 

(7) 将 光标 定位 在 "</P > "之 前 ,输入 “通过 ”。 

(8) 按 第 (3) 步 相同 的 方法 分 别 为 GWCJB 中 的 笔试 成 绩 和 面试 成 绩 字段 创建 对 应 
表单 控件 。 

(9) 光标 定位 在 * </P > "之 后 , 单 击 “ 插 入 "菜单 一 “表单 ”一 “按钮 "选项 ,“ 类 型 " 选 
择 “ 提 交 " ,输入 名 称 为 上 ,“ 值 "为 “插入 ”, 单 击 “ 确 定 ” 按 钮 。 创 建 的 表单 代码 如 图 10-13 
所 示 。 

(10) 按 快捷 键 Cul +S 保存 文件 名 为 Insert_GWCJB. HTML。 
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body> 
ER <form action="CRGWCJB.PHP" method="post name="Form1"> 
四 时 <P> 身 份 证 号 <input name=" 身 份 证 SS" type="text” /></P> 
国 时 <P> 沿 位 编 S<input name=' 讽 位 篇 引 " type="text* /></P> 
国 因 <P> 资 格 市 核 
<input name= "资格 审核 " type="radio* value="0" checked /> 未 通过 
5 量 <input name= "资格 审核 " type="radio” value="1" /> 通过 </P> 
四 玫 <P> 笔 试 成 绩 <input name= "笔试 成 绩 " type="text /></P> 
四 3 旨 <P> 面 试 成 绩 <input name=" 面 试 成 绩 " type= "text" /></P> 
Wy <input name="t)" type="submit value=" 插 入 " /> 
汪 二 </form> 


</body> </html> 











0 
Ri 
i : 



























图 10-13 用 于 “插入 记录 ”的 表单 


2. 设计 处 理 数 据 的 程序 CRGWCJB. PHP 


(1) 在 Dreamweaver 中 ,新 建 CRGWCJB. PHP 文件 。 
(2) 编写 和 优化 后 的 CRGWCJB. PHP 代码 如 下 : 


<HIML > <Head > Meta Http Equiv ="Content -Type" Content ="Text/HIML; Charset TF -8" / 


> 

<Title : 痊 和 成绩 信息 </Title ></Head > 

<Body ><?PHP 
If (Strlen (Trim( $ POST[ "身份 证 号 '])) = 习 8 And Strlen (Trim( $ POST[' 岗 位 编号 '])) = 
5) 


{ $InsertSQL ="Insert Into GWCJB Values ('". $ POST[' 身 份 证 号 ']."',，'" . 
$_POST[' 岗 位 编号 '] ."','". $ POST[' 资 格 审核 '] ."','". $ POST[' 笔 试 成 绩 '] . 
POST 面试 成 绩 吕 。。 "> 
$Link MySQL Pconnect ("LocalHost", "ywy", "ywy211"); // 连接 数据 库 服务 器 
If (! SLink) Die (MySQL Error()); // 连接 数据 库 服 务 器 失败 ,输出 错误 信息 ,退出 程序 
If (!MySQL Select DB("RCZp" , $Link)) Die (MySQL Error ()); 

// 选择 数据 库 失败 ,退出 程序 
MySQL Query ("Set Names 'UTF -8' ");  // 发 送 字符 集 语句 
If (MySQL Query( SInsertSQL, $SLink)) ”Echo "记录 插入 成 功 !1"; ”// 发 送 Insert 语 
Else Echo "记录 插入 失败 !"; } 
Else Echo "身份 证 号 或 岗位 编号 位 数 错误 !"; 
?></Body ></HIML > 


(3) 保存 文件 CRGWCJB. PHP ,运行 Insert_GWCJB. HTML ,可 以 尝试 输入 有 关 数 据 。 


10.4.2 设计 删除 和 修改 数据 记录 的 程序 


在 浏览 器 中 删除 或 修改 数据 记录 时 ,通常 要 在 浏览 器 中 以 表格 形式 显示 数据 记录 ,每 
行 设计 “删除 "和 “修改 "链接 。 当 用 户 单 击 “ 删 除 ” 链 接 后 ,执行 删除 的 程序 ,从 数据 库 中 
删除 所 在 行 的 数据 记录 ; 当 用 户 单 击 “修改 "链接 后 ,执行 显示 当前 行 数据 的 表单 页 面 , 为 
用 户 提供 修改 数据 界面 ,再 单 击 * 更 新 ”按钮 后 ,将 修改 后 的 数据 保存 到 数据 库 。 
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【 例 10.9】 设计 删除 和 修改 GWB 中 数据 记录 的 网 页 程序 。 
1. 显示 岗位 信息 的 程序 设计 
显示 岗位 信息 及 删除 和 修改 链接 的 程序 GCWBXS. PHP 中 的 代码 如 下 : 


<HIML ><Head > 
<Meta HTTP Faquiv ="Content -Type" content ="text/html; Charset -UTF -8"/ > 
<Title > 显示 岗位 表 数 据 </Title ></Head > 
<Body ><Table border ="1" cellpadding ="2" ><Caption > 
<strong 剖 除 和 修改 岗位 信息 </strong ></Caption > 
<tr ><th 疯 位 编号 <th > 岗位 名 称 <th 北 低 学 历 <th 最 低 学 位 <th > 人 数 <th > 年 龄 


上 限 
<th > 年 薪 <th 兹 试 成 绩 比例 <th 次 试 日 期 <th 北 任 要 求 <th > 公司 名 称 <th : 操 
作 1 
<th :操作 2 <wtr > 
<2PHP $link MySQL PConnect ("LocalHost", "ywy", "ywy211") ; ”// 连接 数据 库 服务 器 
MySQL Select DB ("RCZP", $link); // 选择 数据 库 
MySQL Query ("Set Names 'utf8'", $link) ; // 发 送 MysQL 语句, 设置 字符 集 


S$gwib MySQL Query ("Select * From GWB Order By 岗位 编号 ", $link); 
// 发 送 SQL 语句 
Srow_gwb MySQL Fetch Array ( $gwb); // 获取 第 一 行 数据 
Do { ?> 
<tr ><td ><?PHP Echo $row_gwb[' 岗 位 编号 ']; ?> 
<td ><?PHP Echo $row_gwb[' 岗 位 名 称 ']; ?> 
<td ><?PHP Echo $row_gwb[' 最 低 学 历 ']; ?> 
<td ><?PHP Echo $row_gwb[' 最 低 学 位 ']; ?> 
<td ><2PHP Echo Srow gwb['" 人 数 ']; ?> 
<td ><?PHP Echo $row gwb[' 年 龄 上 限 ']; ?> 
<td ><?PHP Echo $row gwb[' 年 薪 ']; ?> 
<td ><?PHP Echo $row_gwb[' 笔 试 成 绩 比例 ']; ?> 
<td><?PHP Echo $row_gwb[' 笔 试 日 期 ']; ?> 
<td ><?PHP Echo $row_gwb[' 聘 任 要 求 ']; ?> 
<td > QPHP Echo $row_gwb[' 公 司 名 称 ']; ?> 
<td > <a href "GWBSC .PHP?GWBH =<?PHP Echo $row_gwb[' 岗 位 编号 ']; 
// 生成 带 岗 位 编号 参数 的 程序 文件 链接 ? >" 前 除 </a> 
<td ><a href "GWBXG .PHP?GWBH =<?PHP Echo $row_gwb[' 岗 位 编号 '];? >" > 修 
改 <a> 
</tr> 
<2PHP } While ( $row gwb MySQL Fetch Array( Sovib)); ?> 
</Table ></Body > </HIML > 


程序 GWBXS. PHP 在 浏览 器 中 的 运行 效果 如 图 10-14 所 示 。 
2. 删除 当前 岗位 信息 记录 的 程序 PHP 设计 
当 浏 览 器 用 户 单 击 图 10-14 中 的 “删除 ”链接 后 ,将 删除 当前 行 的 岗位 信息 ,程序 文件 
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到 除 和 从 改 沿 在 信息 

丙 位 编 所 | 次 位 名 称 最 长 学历 [大任 学 位 人 数 年 营 上 原 年 秘 笔 试 表 世 比 例 笔试 日 期 村 在 要 来 公司 名 称 “操作 1 [操作 2 
[A0001 。 抹 长 二 至 “3 EB 本 区 1 网 0170114 有 各 旺 ， 笔 二 经 济 4 多 融 LE 

A0002 银行 柜员 2 上 sl 0 mm 2017.0115 | 计算 机 二 级 ， 笔 藕 ， 全 融会 计 学 工商 前 进 支行 删除 “| 仿 改 
ao003 了 赋 抽 上 忆 加 2 2017 0115 | 有 寺 照 ， 笔 坛 既 济 ! 丛 融 ER 

A0004 会计 BB 上 EB 0 |@ 2017.05-0 | 生 这 么 草 学 * 恰 天 [5 商 商 进 支 和 员 除 

B0001 [经理 一 吾 “5 5 让 加 2m [2017.0121 | 笔试 ， 经济 学 + 人 力 资源 | 碳 讯 总 公司 

Boooz 。 理财 师 3 E wm [3 9 四 [2017.01-22 | 笔试 : 经济 法 + 财务 管理 | 匡 讯 总 公司 

B0003 | 丙 前 二 可 而 3 3 EE 了 臣 0 | 2017.05 8 | 逢 试 经 开学 + 全 而 + 请 用 行 对 




















图 10-14 删除 和 修改 岗位 信息 表 界面 


GWBSC. PHP 中 的 代码 如 下 : 


<HIML > <Head ><Meta HTTP Fiquiv ="Content -Type" content ="text/html; Charset JTF -8"/ > 
<Title 测 除 岗位 表 数 据 </Title ></Head > 


<Body > 
<2PHP 人 RCZPLJ =MySQL PConnect ("LocalHost", "ywy", "ywy211"); // 连接 数据 库 服 务 器 
MySQL Select DB ("RCZP") // 选择 数据 库 
MySQL Query ("Set Names 'utf8'") ; // 发 送 MysQL 语 句 , 设 置 字符 集 
$sql ="Delete From GWB Where 岗位 编号 ='". $ GET['GWBH'] ."'"; 
// 从 链接 程序 文件 参数 中 获取 删除 记录 的 岗位 编号 
If (MySQL Query ( $5q1)) // 发 送 Delete From 语 句 
Header ("Location: GWBXS.PHP"); // 删除 记录 成 功 , 刷新 岗位 信息 表 ; 
Else Echo "删除 记录 失败 !1"; ?> 
</Body > </HIML > 


3. 显示 与 修改 当前 岗位 信息 的 表单 程序 设计 

当 浏览 器 用 户 单 击 图 10-14 中 的 “修改 "链接 后 ,应 该 运行 程序 文件 GWBXG. PHP ,以 
表单 的 形式 显示 当前 岗位 信息 ,以 便 允 许 用 户 修改 保存 岗位 信息 。 在 GWBXG. PHP 中 设 
计 表 单 及 显示 当前 岗位 信息 的 程序 代码 如 下 : 


<HIML ><Head > Meta HTTP -Equiv ="Content -Type" content ="text/html; Charset -=UTF -8"/ > 
<Title > 修改 岗位 数据 记录 </Title ></Head > 


<Body > 

<?PHP 
Sowbh =$ GET['GWBH']; // 从 链接 程序 文件 参数 中 获取 当前 岗位 的 编号 
$1ink MySQL PConnect ("LocalHost", "ywy", "ywy211") ; // 连接 数据 库 服务 器 
MySQL _ Select_DB ("RCZP", $1ink); // 选择 数据 库 
MySQL _ Query ("Set Names 'utf8'", $link); // 发 送 MySsQL 语句 ,设置 字符 集 


Sgw -MySQL Query ("Select * From GWB Where 岗位 编号 =' Sgwibh'", $link); 
// 发 送 SQL 语句 ,查询 当前 岗位 数据 
Srow gw MySQL Fetch Array ( $gw); // 获取 当前 岗位 数据 ? > 
<Form Action "GWBXG. PHP" Method "Post" Name —"fiml" > 
了 字 疯 位 编号 <Input Name 二 岗位 编号 "Type ="text" Value = <?PHP Echo Sgwbh;?>" /> 
</p> 
他 疯 位 名 称 <Input Name 一 "岗位 名 称 " Type "text" 
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Value =" <?PHP Echo Srow gw[" 岗 位 名 称 "]s 
// 用 当前 岗位 的 数据 填写 表单 控件 的 值 ?>" /></p> 
<?PHP 泉 =Srow_ gw[" 最 低 学历 ']7? > 中 凝 低 学 历 ”<Select Name = 最 低 学 历 " size ="1" > 
<Option Value 村 <?PHP If ($=) Echo 'Selected'; 
// 填 单 选 按钮 值 ?> 习 无 </option > 
<Option Value 之 <?PHP If ( 抠 = 之 ) Echo 'Selected';?> 兴 专科 </option > 
<Option Value 3 <?PHP If ( $x=33) Echo 'Selected';?> 冯 本 科 </Option > 
<Option Value 也 <?PHP If ( 皂 = 忆 ) Echo 'Selected';?>A 研究 生 </Option > 
<Option Value 5 <?PHP If ( $x=3) Echo 'Selected';? >5 博士 woption ></Select >< 
/p> 
<2PHP 人 x=S$row_gw[' 最 低 学 位 '];? ><p 凝 低 学 位 <Select Name = 最 低 学 位 " Size "1" > 
<Option Value 本 <?PHP If ( 公 = 习 ) Echo 'Selected';?> 尖 无 </Option > 
<Option Value 之 <2PHP If ( 泉 = 之 ) Echo 'Selected';? > 况 学 士 </Option > 
<Option Value 3 <?PHP If ( x=33) Echo 'Selected'7? > 冯 双 学 士 Option > 
<Option Value 4 <?PHP If ( $=) Echo 'Selected';?>5M 硕士 </Option > 
<Option Value 上 5 <?PHP If( 们 = 起 ) Echo 'Selected';? > 汪 博 士 </Option ></Select >< 
/p> 
中 > 人 数 <Input Name =" 人 数 " Type ="Text" Value "<2PHP Echo Srow gw[' 人 数 '];?>" />< 
/p> 
< 介 > 年龄 上 限 <nput Name > 年 龄 上 限 " Type ="Text" 
Value = <?PHP Echo $row_gw[' 年 龄 上 限 '];?>" /></p> 
外海 薪 <Input Name 一" 年薪 " Type ="Text" Value =" <?PHP Echo $row gw[' 年 薪 '];?>" />< 
/p> 
外 阁 试 成 绩 比例 <Input Name = 笔试 成 绩 比 例 " Type ="Text" 
Value =" <?PHP Echo $row_gw[' 笔 试 成 绩 比 例 '];?>" /> </p> 
< 候 次 试 日 期 Znput Name 二 笔试 日 期 " Type ="Text" 
Value=" <?PHP Echo $row_gw[' 笔 试 日 期 '];? >" /></p> 
他 滑 任 要 求 <TextArea Name 二 聘任 要 求 " Cols -50 Rows 汪 > 
<?PHP Echo Srow_gw[" 聘 任 要 求 '] ; 
// 填写 文本 区 域 的 值 ? ></Textarea ></p > 
外 公司 名 称 <Input Name =" 公 司 名 称 " Type ="Text" 
Value C2PHP Echo $row_gw[' 公 司 名 称 '];? >"/ ></p> 
<Input Name ="GX" Type "Submit" Value 二 "更 新 记录 " /></Fom> 
<?PHP ”// 更 新 岗位 信息 的 程序 段 代码 ?></Body ></HIML > 


在 浏览 器 中 运行 GWBXG. PHP 的 效果 如 图 10-15 所 示 。 
4. 更 新 岗位 信息 的 程序 设计 


浏览 器 用 户 在 图 10-15 中 修改 数据 后 , 单 击 “ 更 新 记录 "按钮 ,应 该 将 修改 后 的 数据 存 
储 到 RCZP 数据 库 的 岗位 表 GWB 中 。 在 GWBXG. PHP 中 代码 的 </Form > 和 </Body > 
之 间 , 设 计 程 序 段 代 码 如 下 : 


<EHP 


IE (isset($ POST["GX"])) // 分 支 判 断 是 否 单 击 * 更 新 记录 "按钮 
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商 位 编号 [A0002 
岗位 名 称 | 银行 柜员 
景 你 学 历 [2 科 国 | 
最 多 学 位 
5 | 


年 龄 上 限 [24 





年 区 [0 
笔试 成 绩 比例 [70 


笔试 日 期 |2017-01-15 


| 于 间 机 三 筑 ， 香 试 ， 金融 1 会 计 芝 
聘任 要 求 | 





公司 名 称 开 丙 疡 肖 征 
EE 
图 10-15 ”修改 岗位 信息 的 表单 





{ // 用 表单 控件 上 的 数据 ,组 织 Update 语句 , 存储 到 变量 $sql 中 
$sql ="Update GWB Set 岗位 编号 ="'"". $ POST[' 岗 位 编号 '] . 
,岗位 名 称 ='". $ POST[' 岗 位 名 称 '] ."' ,最 低 学 历 ='".$ POST[' 最 低 学 历 '] . 
,最低 学 位 ="'". $ POST[' 最 低 学 历 '] ." ,人 数 =". $ POST['" 人 数 '] . 
"年 龄 上 限 =". $_POST[' 年 龄 上 限 '] .", 年 薪 =". $ POST[' 年 薪 '] . 
", 笔 试 成 绩 比 例 =". $ POST[' 笔 试 成 绩 比例 '] .", 笔 试 日 期 ='". $ POST[' 笔 试 日 期 ']. 
"' ,聘任 要 求 ='". $ POST[' 聘 任 要 求 '] ."' Where 岗位 编号 ="'". $ GET['GWBH'] ."'"; 
If (MySQL Query ( $sq1)) // 发 送 Update 语句 
Header ("Location: GWBXS.PHP"); // 更 新 记录 成 功 , 刷新 岗位 信息 表 ; 
Else Echo "更 新 记录 失败 !"; } ?> 


10.4.3 删除 和 修改 数据 记录 的 程序 设计 向 导 


删除 和 修改 数据 记录 程序 的 另 一 种 设计 方法 是 Dreamweaver 向 导 , 其 优点 是 通过 可 
视 化 操作 和 少量 的 程序 编码 完成 程序 设计 ;缺点 是 系统 生成 的 代码 量 大 ,不 易于 阅读 , 难 
于 系统 维护 和 版 本 更 新 。 


1. 显示 岗位 信息 的 向 导 

(1) 启动 Dreamweaver, 单 击 PHP 选项 ,新 建 一 个 空白 的 PHP 网 页 。 

(2) 单 击 “ 绑 定 " 面 板 中 的 + ”一 “记录 集 ( 查询)" 选 项 。 在 “记录 集 ” 对 话 框 中 设置 
“名 称 " 为 gwb,“ 连 接 " 为 Link, “表格” 为 GCWB,“ 列 "选择 全 部 , “筛选 "为 无 ,“ 排 序 " 为 
无 , 单 击 “ 确 定 "按钮 。 
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(3) 单 击 “ 插 入 "菜单 一 “数据 对 象 " 一 “动态 数据 "一 “动态 表格 ”选项 ,在 “动态 表 
格 " 对 话 框 中 ,设置 “记录 集 "为 gwb,“ 显 示 " 选 择 “ 所 有 记录 ”, 输入 “边框 "为 1,“ 单 元 格 
边 距 "为 2,“ 单 元 格 间距 ”为 0, 单 击 “ 确 定 ” 按 钮 。 

(4) 切换 到 “代码 "视图 ,在 <table border ="1" cellpadding ="2" cellspacing ="0" > 
标记 之 后 输入 以 下 内 容 ，< caption > 删除 和 修改 岗位 信息 < /caption > 。 

(5) 切换 到 “设计 "视图 , 单 击 表 格 中 显示 “公司 名 称 ” 的 单元 格 , 单 击 “ 插 入 "菜单 一 
“表格 对 象 " 一 “在 右边 插入 列 " 选 项 ,在 插入 的 新 列 中 上 面 的 单元 格 内 输入 “操作 1” ,下 
面 的 单元 格 内 输入 “删除 ”。 

(6) 单 击 “ 操 作 1 单元 格 , 单 击 * 插 和 人 "菜单 一 "表格 对 象 " 一 "在 右边 插入 列 " 选 项 ， 
在 插入 的 新 列 中 上 面 的 单元 格 内 输入 “操作 2” ,下面 的 单元 格 内 输入 “修改 ”。 

(7) 选中 文字 “删除 ” ,在 “属性 "面板 的 “链接 "文本 框 中 输入 以 下 内 容 : 

SCGWB .PHP?GWBH =<?PHP Echo $ row_gwb[' 岗 位 编号 '];? > 

(8) 选中 文字 “修改 ” ,在 “属性 "面板 的 “链接 "文本 框 中 输入 以 下 内 容 : 


XGGWB .PHP?GWBH =<?PHP Echo $ row_gwb[' 岗 位 编号 '];? > 


(9) 按 快捷 键 Cul +S 保存 文件 ,设置 文件 名 为 XSGWB. PHP , 按 F12 键 预览 ,效果 如 
图 10-14 所 示 。 


2. 删除 当前 岗位 信息 记录 的 程序 向 导 
(1) 在 Dreamweaver 中 新 建 一 个 PHP 网 页 ,在 “服务 器 行为 "面板 中 , 单 击 * + ”按钮 一 
“删除 记录 ”选项 。 


(2) 在 “删除 记录 ”对 话 框 中 ,按照 图 10-16 进行 设置 , 单 击 * 确 定 "按钮 ,在 “服务 器 
行为 "面板 中 增加 “删除 记录 (Link ,gwb) "选项 。 

































































删除 记录 7 
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图 10-16 设置 “删除 记录 ”对 话 框 
(3) 按 快捷 键 Cul + S 组 合 键 ,保存 文件 名 为 SCGWB. PHP ,并 关闭 文件 。 
3. 显示 与 修改 当前 岗位 信息 的 表单 设计 向 导 


(1) 在 Dreamweaver 中 单 击 "文件 "菜单 -新 建 "选项 ,选择 "空白 页 "页面 类 型 
为 PHP,“ 布 局 "为 无 , 单 击 “ 创 建 " 按 钮 。 
(2) 单 击 “ 绑 定 " 面 板 中 的 + "一 “记录 和 集 (查询 )" 选 项 。 在 “记录 和 集 ”对话 框 中 按照 
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图 10-17 进行 设置 , 单 击 * 确 定 ” 按 钮 。 
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图 10-17 绑 定 记 录 集 


(3) 在 “设计 ”视图 下 , 单 击 “ 插 入 "菜单 一 “表单 ”一 “表单 ”选项 。 
(4) 将 光标 定位 在 表单 中 , 单 击 “ 插 入 "菜单 一 “表单 "一 “文本 域 " 选 项 ,在 对 话 框 中 
按 图 10-18 所 示 进 行 设置 。 





[ 拍 入 标 答 博 助 功 能 性 ”SsS”》SE 区 号 ] 
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日 使 用 or 后 性 附加 标 答 标 记 
样式 . 加 用 标 和 标记 环绕 
回 无 标签 标记 
位 置 回 在 表单 项 前 
日 在 表单 项 后 
访问 键 - Tab 键 索引 - 
如 果 在 播 和 对象 时 不 想 输 入 此 仿 息 ， 造 更 改 - 镍 
助 功能 "首选 参数 。 




















图 10-18 ”设置 “文本 域 " 的 各 项 参数 


(5) 选中 文本 域 , 单 击 * 属 性 ?面板 中 “初始 值 " 文本 框 右 侧 的 “ 绑 定 到 动态 源 " 按钮 ， 
在 “动态 数据 ”对话 框 中 , 单 击 * 记 录 集 ( gw)" 左 侧 的 * + ”按钮 展开 记录 和 集 , 选 中 与 控件 对 
应 的 字段 (岗位 编号 ) , 单 击 * 确 定 "按钮 实现 控件 与 数据 的 绑 定 。 

(6) 按 第 (4) 和 (5) 步 的 方法 为 GWB 的 岗位 名 称 创建 表单 控件 并 绑 定数 据 。 

(7) 在 表单 中 , 单 击 “插入 "菜单 一 “表单 "一 “选择 ( 列表 /菜单 )" 选 项 ,设置 “ID” 和 
“标签 " 均 为 最 低 学 历 , 其 他 项 为 默认 值 。 

(8) 选中 “选择 "控件 ,在 “属性 "面板 中 , 单 击 “ 动 态 .. ”按钮 ,在 “动态 列表 /菜单 ”对 
话 框 中 按照 图 10-19 进行 设置 ,然后 单 击 “ 选 取 值 等 于 "文本 框 右 侧 的 “ 绑 定 到 动态 源 " 按 
钮 ,在 “动态 数据 "对 话 框 中 展开 记录 集 ( gw) ,选中 “最 低 学 历 " 字 段 , 单 击 “ 确 定 ” 按 钮 , 回 
到 ”动态 列表 /菜单 "对 话 框 中 ,最 后 单 击 * 确 定 "按钮 。 

(9) 重复 第 (7) 和 第 (8) 步 ,为 “最 低 学 位 "字段 创建 对 应 的 选择 控件 ,静态 选项 的 
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图 10-19 设置 “选择 控件 "的 列表 值 


“ 值 "分 别 为 1.2.3.4 和 5 ,标签 "分 别 对 应 1 无 .2 学 士 ,3 双 学 士 4 硕士 和 5 博士 , 绑 定 
的 动态 数据 源 为 记录 集 ( gw) 中 的“ 最低 学 位 "字段 。 

(10) 按 第 (4) 和 第 (5) 步 为 GWB 的 人 数 \ 年 龄 上 限 ,年薪 笔试 成 绩 比 例 和 笔试 日 期 
等 字段 创建 对 应 的 文本 域 控件 ,并 绑 定 对 应 的 动态 数据 源 。 

(11) 按 Enter 键 后 输入 “聘任 要 求 ” ,在 “代码 "视图 下 , 单 击 “ 插 入 "菜单 一 “表单 ”一 
“文本 区 域 " 选 项 ,在 “标签 编辑 器 ”对话 框 中 输入 “名 称 ”为 “聘任 要 求 ",“ 列 "为 50,“ 行 
数 ” 为 3, 单 击 “ 确 定 ”" 按 钮 。 在 ”</TextArea > "前 输入 代码 <? PHP Echo $row_gw[ 
聘任 要 求 ']; ? >”。 

(12) 按 第 (4) 和 第 (5) 步 为 GWB 的 公司 名 称 字段 创建 对 应 的 文本 域 控件 ,并 绑 定 对 
应 的 动态 数据 源 。 

(13) 在 “代码 "视图 下 ,光标 位 于 </Form > 之 前 , 单 击 “ 插 入 "菜单 一 “表单 "一 “ 按 
钮 ”选项 ,设置 按钮 的 “类 型 "为 “提交 ”, “名称 ”为 GX, 值 为 “更 新 记录 ” ,最 后 单 击 “ 确 
定 ”" 按 钮 。 

(14) 在 “设计 "视图 下 表单 效果 如 [二 
图 10-20 所 示 , 按 Cul+S 组 合 键 ,设置 文件 一 
名 为 XGGWB. PHP , 单 击 “保存 "按钮 。 











秽 位 名 称 [CRER echo Srov-gv[ 两 位 大 称 "J 35 
4. 绑 定 “更 新 记录 " 服务 出 和 欧 赂 kPasE 旧 
最 低 学 位 [357K# 士 区 





(1) 打开 XGGWB. PHP 文件 ,在 “服务 器 | 人数 FE ec sweTX 了 到 
行为 "面板 中 , 单 击 * 下 ”更 新 记录 ”选项 。 eta <?php echo $row_gw[ 年 龄 上 限 "]; ?> : 
eb b XIphp echo $row gw[ 年 医 ']; ?> : 
(2) 在 “更 新 记录 ”对 话 框 中 ,按照 图 | 郊 访 入 比 例 [mp san rov iT 可 二 有 旷 他 : 
10-21 进行 设置 , 单 击 “ 确 定 ” 按 钮 ,在 “服务 | 笔试 9 期 [connn echo 3rowewT 让 直 同 J 35 : 
知行 为 "面板 中 增加 * 更 新 记录 (fornl ,Link， | jg 
gwb) "选项 。 公司 名 称 
(3) 按 快捷 键 Cul +S 保存 此 文件 。 i 


10-20 “修改 记录 ”中 的 表 旱 设计 



































《<?php echo $row_gw[ 公司 名 称 ];， ?》 
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提交 为 ee 
| 在 更 新 后 ， 转 到 : X56 是. PP 
































图 10-21 设置 “更 新 记录 ”对 话 框 


“最 低 学 历 " 和 "最 低 学 位 ” 
的 数据 类 型 设置 为 "文本 ” 


10.5 ”用户 注册 网 页 程序 设计 


网 站 用 户 注册 是 很 常用 的 一 个 功能 , 几 


乎 每 个 动态 交互 式 的 网 站 都 有 一 个 注册 模块 用 来 实现 用 户 注 册 。 
【 例 10.10】 以 RCZP 数据 库 为 例 ,设计 如 图 10-22 所 示 的 个 人 用 户 注册 页 面 ,将 注 


册 信 息 添加 到 YPRYB 中 (使 用 身份 证 号 作为 密码 ) 。 
1. 设计 用 户 注册 页 面 
用 户 注册 网 页 应 用 程序 Register. PHP 的 代码 如 下 : 


<HIML > 
<Head ><Meta HTTP -Equiv ="Content -Type" Content ="Text/ 
HIML; CharSet TF -8" /> 
<Title > 注册 页 面 /Title ></Head > 
<Body > 
<Eorm Action 3"2C.php" Method ="POST" Name ="fomml" > 
< 也 3 身份 证 号 <Input Type ="Text" Name 一 身份 证 号 "/ > 
</P> 
< 姓名 <Input Type "Text" Name 一 姓名 "/ ></P> 
也 滤 否 <Select Name 一 婚 否 "> 
<Option Value 2"1" 沁 婚 </Option > 
<Option Value ="0" Selected > 未婚 woOption > 
</Select ></P> 
心 盖 后 学 历 
<Select Name = 最 后 学 历 " ><Option Value =1" > 无 </ 
Option> 
<Option Value 2"2" Selected > 专科 </Option > 































































































移动 电话 
[广角 
图 10-22 注册 页 面 
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<Option Value "3" 3 本科 </Option > 
<Option Value "4" > 研究 生 </Option > 
<Option Value "5" >: 精 士 </Option ></Select ></P> 
也 凝 后 学 位 <Select Name 二 最 后 学 位 ”> 
<Option Value =1" > 无 </Option > 
<Option Value ~"2" Selected 六 十 </option > 
<DOption Value "3" > 双 学 士 </Option > 
<Option Value "4" 巴士 </Option > 
<Option Value=5" 靖 士 woption > </Select ></P> 
也 浙 学 专业 <Input Type ="Text" Name 一 所 学 专业 "/ ></P> 
< 通讯 地 址 <Input Type ="Text" Name 一 "通讯 地 址 "/ ></P > 
< 法政 编码 Xnput Type ="Text" Name 一" 邮政 编码 "/ ></P > 
< mail 账号 <Input Type ="Text" Name "Email 账号 "/ ></P> 
< 也 XQ 账号 <Input Type ="Text" Name "0 账号 "/ ></P> 
卫 凋 定 电话 Xnput Type ="Text" Name 二 "固定 电话 "/ ></P> 
也 靖 动 电话 Xnput Type ="Text" Name 下 "移动 电话 "/ ></P> 
< ><Input Type 2"Submit" Name ="Button" Value =" 注 册 "/ ></P > 
</Fom > </Body > </Html > 


2. 注册 模块 的 网 页 程序 代码 
处 理 表单 数据 的 网 页 应 用 程序 ZC. PHP 的 代码 如 下 : 


<?PHP 
SLink MySQL Pconnect ("LocalHost", "ywy", "ywy211"); // 连接 数据 库 服务 器 
MySQL Select DB ("RCZP"，SLink) // 选择 当前 数据 库 


MySQL Query ("Set Names 'UTF -8'"); 

$sql "Select 身份 证 号 From ypryb Where 身份 证 号 ="'". $ POST[' 身 份 证 号 ']."'"; 

$LOginRS -MySQL Query( $sql, $Link) Or Die (MySQL Error()); 

$RS -MySQL Num Rows ( SLoginRS) 7 

If( SRSx ) // 若 身份 证 号 已 经 存在 , 则 注册 失败 

{ Echo "身份 证 号 已 经 存在 ,注册 失败 !"; Die () ;} 

If (Strlen (Trim( $ POST[' 身 份 证 号 '])) = 所 8) 

{ ”Squery ~"Insert Into ypryb (身份 证 号 , 姓名 , 婚 否 , 最 后 学 历 , 最 后 学 位 , 所 学 专业 ， 
邮政 编码 ,Email 账号 , QQ 账号 ,固定 电话 ,移动 电话 ,密码 ) 


VALUES ( rm $_POST[' 身 份 证 号 ']."','". $ POST[' 姓 名 '] .""',". 
$_POST[' 婚 否 '] .",'". $ POST[' 最 后 学 历 '] ."'，'". 
$_POST[' 最 后 学 位 '] ."','". $ POST[' 所 学 专业 ']."'，"". 


$_POsT[' 邮 政 编码 '] ."'，'"。$ POST['Email 账号 .sr. 
$ POST[' QQ 账号 '] ."','".$ POST[' 固 定 电话 ']."',"'". 
$_POST[' 移 动 电话 '] .""','". $ POST[' 身 份 证 号 '] ."')"; 
If (MySQL Query ( $query, $Link) ) Echo "注册 成 功 !"; Else Echo "注册 失败 !"; } 
Else Echo "身份 证 号 位 数 错误 !1"; ?> 
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习 题 


一 、 填 空 题 

1. 在 Dreamweaver 中 ,如 果 要 在 网 页 上 使 用 动态 数据 ,首先 要 建立 一 个 QD ,然后 
选择 一 种 “四 ,再 设置 站 点 的 ”@) ,最 后 通过 绑 定 _@ 实现 动态 数据 的 使 用 。 

2. 在 Dreamweaver 中 建立 MySQL 连接 后 , Dreamweaver 会 自动 建立 一 个 叫做 @ 
的 文件 夹 ,其 中 有 一 个 与 之 前 所 建立 的 MySQL 连接 名 称 相同 的 _@ 文件 。 

3. 在 PHP 中 实现 与 MySQL 数据 库 连 接 的 函数 是 _ 中 ,关闭 连接 使 用 的 是 @ 
函数 。 

4. 使 用 命令 通知 服务 器 从 客户 端 发 送 来 的 信息 采用 的 字符 集 , 并 保证 服务 器 发 送 回 
客户 端的 信息 也 采用 相同 的 字符 集 , 以 避免 乱码 的 产生 。 

5. 网 页 不 能 直接 访问 数据 库 中 存储 的 数据 ,而 是 需要 与 “中 ”进行 交互 , 它 是 
”加 的 结果 。 

6. 实现 记录 集 与 页 面 的 绑 定 ,应 该 在 Dreamweaver 的 _ 中 面板 中 , 单 击 _@ 按 
钮 ,在 弹出 的 菜单 中 选择 ”@) 菜单 项 。 

7. 允许 用 户 向 数据 库 中 插入 新 记录 的 网 页 应 该 由 两 个 部 分 组 成 : 一 个 允许 用 户 输 
入 数据 的 _Q(D 和 一 个 更 新 数据 库 的 _®@® 。 

8. 在 动态 网 页 中 ,经常 需要 用 户 在 浏览 器 上 通过 表单 向 数据 库 服务 器 提交 数据 。 当 
表单 以 GET 方法 发 送 数据 时 ,应 该 使 用 _ 四 “接收 数据 , 当 表 单 以 POST 方法 发 送 数据 ， 
则 应 该 使 用 _@) 接收 数据 。 

9. 在 PHP 中 利用 QD 函数 向 MySQL 数据 库 服务 器 发 送 SQL 语句 ,然后 在 @ 
上 执行 ,而 不 是 在 PHP 脚本 中 执行 这 条 语句 。 

二 、 单 选 题 

1. 在 Dreamweaver 中 建立 了 MySQL 数据 库 连接 后 ,以 下 关于 相应 的 PHP 代码 的 说 
法 中 错误 的 是 ( ) 。 

A. 相应 代码 由 Dreamweaver 自动 生成 

B. 切换 到 “代码 "视图 可 以 查看 代码 

C. 代码 是 只 读 的 ,不 可 以 修改 

D. 代码 中 用 MySQL_Pconnect 函数 连接 数据 库 

2. 在 Dreamweaver 中 为 data. PHP 建立 了 一 个 名 为 DataLink 的 数据 库 连 接 后 ,在 
Connections 文件 夹 中 会 出 现 ( ) 文 件 。 

A. data. PHP B. DataLink. PHP 
C. data. HTML D. DataLink. HTML 
3. 以 下 关于 数据 库 连 接 的 说 法 正确 的 是 ( )。 
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A. MySQL_Connect 函数 可 以 创建 持久 性 连接 
B. MySQL_Pconnect 函数 可 以 创建 非 持久 性 连接 
C. 脚本 执行 结束 ,由 MySQL_Connect 创建 的 服务 器 连接 就 会 被 关闭 
D. 可 以 使 用 MySQL_Close 函数 关闭 由 MySQL_Pconnect 创建 的 连接 
4. 以 下 关于 在 Dreamweaver 中 修改 数据 库 表 中 记录 的 说 法 ,正确 的 是 ( se 
A. 在 修改 之 前 ,由 搜索 页 在 数据 库 中 找到 要 改 的 记录 
B. 搜索 页 是 用 来 设置 搜索 条 件 的 页 面 
C. 更 新 页 将 更 新 后 的 内 容 显 示 出 来 
D. 结果 页 将 修改 后 的 结果 显示 出 来 
5. 在 更 新 记录 的 结果 页 中 设置 数据 筛选 条 件 时 ,以 下 说 法 错误 的 是 ( ) 。 
A. 选择 数据 库 表 中 的 一 个 字段 ,用 于 匹配 搜索 页 发 送 过 来 的 查询 条 件 
B. 如 果 搜 索 页 上 的 表单 使 用 POST 方法 , 则 选择 “表单 变量 ” 
C. 如 果 搜 索 页 上 的 表单 使 用 GET 方法 , 则 选择 “URL 参数 ” 
D. 如 果 用 户 在 搜索 页 上 的 表单 中 输入 搜索 参数 , 则 选择 “输入 的 值 ” 
6. 以 下 关于 在 Dreamweaver 中 删除 数据 库 表 中 记录 的 说 法 ,正确 的 是 ( Ws 
A. 在 Dreamweaver 中 可 以 彻底 删除 数据 库 表 中 的 记录 
B. 在 Dreamweaver 中 删除 记录 仅仅 是 逻辑 删除 该 记录 
C. 在 Dreamweaver 中 删除 记录 后 可 以 恢复 该 记录 
D. 在 Dreamweaver 中 利用 “删除 记录 ”客户 端 行为 实现 记录 删除 
7. 以 下 关于 数据 查询 的 相关 函数 的 说 法 正确 的 是 ( ) 。 
A. MySQL_Fetch_Assoc 函数 以 多 维 数组 的 形式 返回 记录 集中 的 所 有 数据 
B. MySQL_Num_Rows 函数 可 以 获得 记录 集中 的 一 行 
C. MySQL_Num_Fields 函数 可 以 获得 记录 集中 的 一 列 
D. MySQL_Field_Name 函数 可 以 获得 记录 集 的 字段 
8. 在 表单 中 执行 代码 : < Input Type =" Text" Name ="name" ID =" 姓名 " / > ,表单 
使 用 POST 方法 发 送 数据 ,( ) 能 够 正确 接收 数据 。 











A. $ Name= $POST[0] B. $ Name= $ POST["name"] 
C. $ Name = 由 POST[" 姓 名 "] D. $ Name= $ POST["Text"] 
三 、 多 选 题 


1. 与 动态 内 容 相关 的 面板 有 绑 定 面板 .服务 器 行为 面板 和 数据 库 面 板 , 关 于 这 些 面 
板 的 说 法 中 正确 的 是 ( Fs 
A. 按 Shift + Ctl +F10 组 合 键 可 以 打开 数据 库 面板 
B. 按 Cul +F10 组 合 键 可 以 打开 绑 定 面板 
C. 按 Shift + F4 组 合 键 可 以 打开 服务 器 行为 面板 
D. 通过 数据 库 面板 可 以 实现 对 数据 记录 的 操作 
E. 只 能 在 绑 定 面板 中 实现 记录 集 的 绑 定 
2. 关于 在 Dreamweaver 中 创建 MySQL 数据 库 连接 的 说 法 正确 的 是 ( Ns 
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局 中 员 天 


. 在 Dreamweaver 中 建立 站 点 后 就 可 以 直接 创建 数据 库 连接 

. 在 “数据 库 ” 面板 中 单 击 * + ”按钮 创建 数据 库 连 接 

. 在 创建 数据 库 连 接 时 必须 指定 用 户 名 和 密码 

. 连接 建立 后 系统 会 自动 创建 名 为 Connection 的 文件 夹 

. 编写 PHP 代码 时 可 以 使 用 MySQL_Connect 函数 建立 数据 库 连 接 


3. 有 PHP 代码 如 下 : <? PHPMySQL_Query( "Set Names 'uft8'" );? > ,关于 此 代码 


的 说 法 正 


确 的 是 ( )。 
. 将 当前 页 面 的 编码 方式 设置 为 UTF-8 


. 将 当前 站 点 中 所 有 页 面 的 编码 方式 设置 为 UTF-8 

. 通知 服务 器 将 来 从 这 个 客户 端 发 送 来 的 信息 采用 UTF-8 编码 方式 
. 设置 服务 器 发 送 回 客户 端的 结果 采用 UTF-8 编码 方式 

. 设置 中 文字 符 集 , 保 证 中 文 不 会 出 现 乱码 


4. 以 下 关于 记录 集 的 说 法 错误 的 是 ( ) 。 


A. 
B. 
C. 
D. 


E 





记录 集 是 数据 库 中 存储 内 容 的 数据 库 表 

记录 集 是 数据 库 查 询 的 结果 

网 页 要 利用 记录 集 才能 够 访问 数据 库 中 的 数据 
创建 记录 集 后 会 显示 在 “数据 库 ” 面 板 中 

. 可 以 将 记录 集中 的 列 直接 拖 动 到 网 页 上 进行 显示 


5. 以 下 关于 数据 记录 的 操作 的 说 法 错误 的 是 ( ) 。 


A 


B 
C 
D 
E 


.Dreamweaver 提供 了 可 视 化 操作 方法 对 数据 记录 进行 处 理 

. 在 Dreamweaver 中 可 以 直接 编写 PHP 代码 实现 记录 的 操作 

. 在 Dreamweaver 中 利用 可 视 化 操作 生成 的 PHP 代码 是 只 读 的 

. 在 Dreamweaver 中 可 以 同时 更 新 多 个 表 中 的 记录 
.Dreamweaver 提供 的 “删除 记录 ”服务 器 行为 可 以 彻底 删除 记录 


,程序 填空 题 
1. 在 Dreamweaver 中 创建 数据 库 连 接 时 ,设置 连接 名 称 为 RCZP,MySQL 服务 器 为 本 


地 服务 器 
件 . QD 


,用 户 名 为 admin ,密码 为 helloMySQL ,数据 库 为 rczp。 在 DW 自动 生成 的 连接 文 
中 ,其 代码 应 该 为 : 


<?PHP $hostname RCZP ="LocalHost"; 


Saatabase RCZP = 加 _"; 

$username RCZP ="admin™"; 

Spassword RCZP ="helloMySQL"; 

SRCZP = ®@® ($hostname RCZP, $username RCZP, S$password RCZP); ?> 


2. 用 户 在 表单 中 填写 各 项 数据 , 单 击 “ 插 入 记录 ”按钮 ,向 mzb 表 中 插入 一 条 记录 。 


网 页 中 的 


部 分 代码 如 下 : 


< 了 并 族 编码 <Input Type ="Text" Name "num" ID="Text1" / ></P> 
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< 也 并 族 名 称 <Input Type ="Text" Name "name" ID="Text2" /></P> 

<P ><Input Type 2"submit" Name —"button" ID =button" Value = 插入 记录 " /></P></Eorm> 

其 中 表 mzb 的 字段 依次 为 : 民族 编码 和 民族 名 称 ( 均 为 文本 ) ,完成 文件 mzb. PHP 中 
的 PHP 代码 ( mzb. PHP 保存 在 站 点 根 目录 中 ) 。 


<?PHP Include "” OD /Link.PHP"; // 包含 连接 文件 
Sm= @ [nom']; mc=$ GET['name']; 
$sql ="Insert Into MZB Values ('". Sam .",". @ .mm)"; 


MySQL Query( $5q1); ?> 
3. GW 表 中 包含 岗位 编码 和 岗位 名 称 ( 均 为 文本 型 ) ,CJ 表 中 包含 身份 证 号 .岗位 编 
码 ( 均 为 文本 型 ) .笔试 和 面试 ( 均 为 数值 型 ) 。 
利用 身份 证 号 查询 此 人 申报 的 所 有 岗位 的 总 成 绩 ,其 中 身份 证 号 通过 表单 中 名 为 
“num” 的 文本 框 ,采用 POST 方法 发 送 到 文件 gwcj. PHP。 在 此 文件 中 查找 身份 证 号 、 岗 位 
名 称 和 总 成 绩 (笔试 + 面试 ) ,并 将 结果 按 总 成 绩 降序 显示 在 网 页 中 ,完成 以 下 PHP 代码 。 


<?PHP Include "Connections/Link.PHP"; // 包含 连接 文件 
$sfzh=$ POST["num']; 
$sql ="Select 身份 证 号 , 岗位 名 称 ， 四 As 总 分 From GW Natural Join CJ 
Where 身份 证 号 =' "” .$sfzh . "' Order By 总 分 DESC " ; 
$result MySQL Query ( $5q1); 
Echo " <Table >"; 
一 和 全 ( $info MySQL Fetch Assco( Sresult) ) 
{ Echo "<IR><ID>" ，$info[' 身 份 证 号 '] ，" </TD>"; 
Echo "<TD >" ，$info[' 岗 位 名 称 '] ,， "</TD>" ; 
Eho"dD>, Hinfof” 国 中 <， 
Echo "</TR>"; } 
Echo " </Table >"; ?> 


五 、 程 序 运 行 结果 填空 题 
1. 数据 库 KS 中 表 CJ 的 字段 及 内 容 如 下 : 


学 号 课程 名 成 绩 
51140106 高 数 85 
33140508 外 语 71 
64130128 数据 库 69 
51140106 外 语 78 
64130128 高 数 63 
33140508 高 数 69 
33140508 数据 库 % 
64130128 外 语 65 


网 页 JS. html 中 表单 部 分 代码 如 下 : 
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< 上 orm ID 一 FormlL" Name 一 FormL" Method ="post" Action 一 PUF.PHP" > 


< 也 ><Input Type "Radio" Name "RadioGroup" Value = 学 号 "/ > 计算 学 生平 均 分 YP> 
< 也 ><Input Type "Radio" Name "RadioGroup" Value 二 课程 名 "/ yi 算 课 程 平均 分 wwP > 
<P><Input Type ="Submit" Name ="Button" Value 一 计算 "/ ></P></Form> 


网 页 PJF. PHP 中 的 代码 如 下 : 


<?PHP 。 $Link -MySQL Pconnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select DB("KS", S$Link); 
MySQL Query ("Set Names 'UTF -8'"); 
$x =$ POST['RadioGroup']; 
$sql ="'Select " . 公 .", Avg (成 绩 ) Rs 平均 分 From cj Group By " 


. $x. "Order By 平均 分 Desc" ; 
Srs -MYSQL Query ( $5q1); 


$info MySQL Fetch Assoc( $rs); ?> 
<Table Width ="200" Border ="1" CellSpacing ="0" CellPadding ="3" > 
<TR ><TH><?PHP Echo $x; ?></TH><TH 症 均 分 </TH></TR> 
<?PHP Do { ?> 
<TR ><TD ><?PHP Echo $info[" $x"]; ?></TD> 
<TD ><?PHP Echo $info[' 平 均 分 ']; ?></TD></TR> 


<?PHP } While ( $info -MySQL Fetch Assoc( $rs)); ?> 
</Table > 


浏览 JS. html 时 ,在 表单 中 选中 “计算 课程 平均 分 "按钮 , 单 击 * 计 算 " 按 钮 后 ,在 表格 
第 一 列 的 第 二 三 .四 行 看 到 的 数据 分 别 是 _ 呈 @ 和 图 





o 


1. 如 果 绑 定 记录 集 时 数据 来 源 是 多 个 表 , 或 者 数据 查询 条 件 时 是 复合 条 件 , 则 应 该 
在 Dreamweaver 中 如 何 进 行 操作 ? 


2. 在 用 户 登录 时 ,虽然 登录 过 程 已 经 验证 用 户 名 与 密码 是 正确 的 ,但 是 当 用 户 跳 转 
到 其 他 页 面 时 ,从 登录 页 面 获得 的 用 户 信息 全 部 丢失 ,这 意味 着 用 户 每 进入 一 个 页 面 时 都 
要 重新 登录 ,进行 身份 验证 ,应 该 如 何 解决 这 个 问题 ? 


3. 在 网 页 访问 计数 器 程序 设计 中 实现 的 是 文字 计数 器 ,如 何 实 现 图 片 计 数 器 ? 
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会 话 是 指 一 个 终端 用 户 与 系统 进行 通信 的 过 程 。 访 问 Web 网 站 时 ,一 个 会 话 是 
指 浏览 器 程序 打开 一 个 网 站 的 网 页 直至 关闭 该 浏览 器 窗口 的 一 段 时 间 。 一 个 会 话 期 
间 ,用 户 可 以 通过 链接 和 表单 提交 等 方式 访问 同一 网 站 的 多 个 网 页 。 通 常 将 服务 器 
端 管理 同一 用 户 发 出 的 不 同 请 求 之 间 的 关联 称 为 维护 会 话 。 维 护 会 话 需要 使 用 会 话 
机 制 。 

会 话机 制 是 一 种 面向 连接 的 可 靠 通信 方式 ,通常 根据 会 话机 制 可 以 判断 用 户 的 身份 
和 保存 其 他 会 话 信息 。 例 如 , 当 用 户 在 某 购物 网 站 成 功 登录 以 后 ,访问 不 同 的 网 页 ,可 以 
完成 浏览 商品 .查看 购物 车 和 商品 结算 等 操作 。 在 同一 个 网 站 的 多 个 网 页 之 间 切 换 时 , 保 
留用 户 身 份 信息 ,记录 用 户 操 作 行为 ,都 需要 使 用 会 话机 制 。 

要 充分 利用 会 话机 制 解决 网 页 之 间 的 数据 传递 问题 ,在 设计 网 络 应 用 程序 时 ,应 该 弄 
清楚 下 列 一 些 问 题 .: 

(1) 会 话机 制 的 作用 是 什么 ? 有 哪 几 种 实现 会 话机 制 的 技术 ?各自 的 特点 是 什么 ? 

(2) 网 页 之 间 为 什么 要 传递 数据 ?如 何 利用 会 话机 制 实现 数据 传递 ? 

(3) 如 何 设 计 和 管理 各 种 会 话机 制 ? 


11.1 会 话 概 述 


访问 Web 网 站 时 ,浏览 器 通过 HTTP 协议 访问 每 一 个 Web 网 页 文件 。 而 HTTP 协 
议 是 一 种 无 状态 的 协议 , 即 HTTP 协议 无 法 维护 同一 个 用 户 的 两 个 事务 之 间 的 状态 。 
当 一 个 用 户 请 求 一 个 网 页 文件 以 后 ,再 请 求 同 一 个 Web 网 站 的 其 他 网 页 文件 时 ,HTTP 
协议 不 能 识别 这 两 个 请 求 来 自 同 一 个 用 户 , 只 能 将 两 次 请 求 作 为 相互 独立 的 请 求 。 

在 同一 个 网 站 的 多 个 网 页 之 间 进 行 切换 时 ,不 仅 需 要 识别 用 户 身份 ,还 需要 记录 用 户 
操作 行为 。 在 HTTP 协议 的 基础 上 ,目前 有 Cookie 和 Session 两 种 技术 ,都 通过 在 服务 器 
端 和 客户 端 存储 会 话 信息 ,拓展 HTTP 协议 头 部 传递 会 话 信 息 来 管理 会 话 ,其 中 Session 
技术 依存 于 Cookie 技术 。 





1，Cookie 技术 


基于 Cookie 技术 的 会 话机 制 ,由 Web 服务 器 启动 会 话 , 在 客户 端 存 储 会 话 信息 。 进 
行 会 话 时 ,客户 端 浏 览 器 提取 出 会 话 信息 ,封装 到 HTTP 协议 头 部 并 发 送 到 Web 服务 器 ， 
Web 服务 器 通过 接收 会 话 信息 识 别 用 户 身 份 。 

虽然 Cookie 技术 实现 了 会 话机 制 ,但 是 还 存在 以 下 缺陷 : 

(1) 会 话 信息 存储 量 小 。 由 于 会 话 信 息 全 部 保存 在 客户 端 ,为 了 防止 恶意 攻击 ,浏览 
器 对 Cookie 文件 的 个 数 和 大 小 都 做 了 限制 ,只 保存 少量 会 话 信息 。 例 如 ,IE11 限制 每 个 
Cookie 文件 大 小 不 能 超过 4KB ,每 个 域 (网 站 域名 ) 至 多 创建 50 个 Cookie 文件 。 

(2) 客户 请 求 速度 慢 。 每 次 HTTP 请 求 都 需要 携带 全 部 会 话 信息 ,降低 了 客户 请 求 
速度 ,增加 了 网 络 通信 数据 量 。 

(3) 会 话 可 能 异常 终止 。 维 护 会 话 依赖 于 客户 端 对 会 话 信息 的 存储 和 发 送 。 客 户 端 
系统 的 稳定 性 和 安全 性 无 法 保证 ,可 能 因为 系统 死机 等 原因 造成 会 话 信息 丢失 或 会 话 异 
常 终止 。 

(4) 会 话 信息 不 安全 。 将 所 有 的 会 话 信息 存储 在 客户 端 ,对 网 站 应 用 系统 有 很 大 的 
安全 隐患 。Cookie 文件 可 能 被 窃取 , 算 改 .复制 和 伪造 ,用 户 信息 安全 得 不 到 保证 。 

(5) 会 话 信息 不 能 跨 平 台 共 享 。 由 于 会 话 信息 全 部 保存 在 客户 端 , 当 用 户 使 用 不 同 
客户 端 登 录 同 一 网 站 时 ,不 能 共享 会 话 信息 。 


2. Session 技术 


通常 用 Session 技术 弥补 Cookie 技术 的 缺陷 ,将 绝 大 部 分 会 话 信 息 存 储 在 服务 器 端 ， 
客户 端 用 Cookie 技术 只 存储 会 话 标识 符 ,并 在 会 话 期 间 将 会 话 标识 符 发 送 至 服务 器 端 。 
用 Session 技术 实现 会 话机 制 ,有 以 下 特点 : 

(1) 会 话 信 息 存 储量 大 。 绝 大 多 数 会 话 信息 保存 在 服务 器 端 ,信息 量 只 受 服务 器 外 
存储 器 空间 的 限制 。 

(2) 客户 请 求 速度 快 。 客 户 端 每 次 只 需要 在 HTTP 请 求 头 部 发 送 会 话 标 识 符 ,减少 
了 网 络 通信 数据 量 , 加 快 了 客户 请 求 速度 。 

(3) 系统 稳定 。 会 话 在 生命 周期 内 由 服务 器 端 维护 ,服务 器 端 有 专用 的 软 硬 件 设备 
保证 系统 稳定 性 ,可 以 降低 信息 意外 丢失 的 可 能 性 。 

(4) 会 话 信息 安全 。 绝 大 多 数 会 话 信息 保存 在 服务 器 端 , 黑 客 只 有 侵入 到 服务 器 才 
能 窃取 \ 臭 改 ,复制 和 伪造 会 话 信息 。 

3. Session 技术 的 缺陷 

Session 技术 进一步 完善 了 会 话机 制 ,但 是 仍 存在 以 下 缺陷 : 

(1) 客户 端 会 话 标识 符 的 存储 和 发 送 依赖 于 Cookie 技术 。 客 户 端 禁 用 Cookie 时 , 需 
要 使 用 其 他 技术 传递 会 话 标识 符 。 

(2) 绝 大 多 数 会 话 信息 保存 在 服务 器 端 ,增加 了 服务 器 端 存 储 设备 的 压力 。 

(3) 大 量 用 户 并 发 访问 服务 器 时 ,所 有 的 会 话 信息 都 需要 服务 器 进行 维护 ,可 能 造成 
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服务 器 端 响应 速度 下 降 或 死机 现象 。 


11.2 Cookie 会 话 技术 


Cookie 是 Web 系统 中 实现 会 话机 制 的 一 种 技术 ,主要 解决 HTTP 协议 管理 会 话 的 问 
题 。 许 多 浏览 器 ,如 Firefox .chrome 和 下 等 都 支持 Cookie 技术 。 


11.2.1 Cookie 会 话 技术 主要 环节 


Cookie 会 话 过 程 有 如 下 4 个 主要 环节 。 
1. 启动 Cookie 会 话 


客户 端 通过 表单 网 页 等 向 服务 器 提交 信息 (如 身份 证 号 和 密码 等 ) ,由 服务 器 验证 信 
息 正确 性 ,并 确定 是 否 需 要 启动 会 话 。 

如 果 需 要 启动 会 话 , 服 务 器 端 将 会 话 信息 (如 用 户 名 等 ) 发 送 给 客户 端 ,客户 端 将 会 
话 信息 存储 到 本 地 存储 器 ( 内 存 或 硬盘 ) 中 。 


2. 获取 Cookie 会 话 信息 


如 果 会 话 信息 存在 ,客户 端 向 服务 器 发 送 请 求 时 ,从 本 地 存储 器 中 读 取 会 话 信息 并 添 
加 到 HTTP 响应 头 部 发 送 给 服务 器 ,服务 器 获取 会 话 信息 ,恢复 会 话 状态 。 


3. 新 增 或 修改 Cookie 会 话 信息 


服务 器 将 新 增 或 修改 的 会 话 信息 ( 如 登录 时 间 和 登录 次 数 等 ) 发 送 给 客户 端 ,客户 端 
将 会 话 信息 存储 到 本 地 存储 器 中 。 


4. 注销 Cookie 会 话 


会 话 信 息 通常 存储 在 客户 端的 内 存 或 磁盘 中 ,具体 存储 位 置 由 浏览 器 设置 和 会 话 有 
效 期 决定 。 所 谓 注 销 会 话 就 是 删除 有 关 会 话 信息 。 

有 如 下 三 种 情况 将 注销 会 话 ,并 删除 本 地 存储 器 中 的 会 话 信息 : 

(1) 会 话 超期 ,生命 周期 结束 。 

(2) 服务 器 发 送 删除 会 话 命令 。 

(3) 会 话 文件 数量 超出 浏览 器 设置 上 限 ,浏览 器 自动 注销 较 早 的 会 话 。 

通常 情况 下 ,如 果 启动 会 话 时 没有 设置 有 效 期 ,会 话 生 命 周期 为 一 次 浏览 器 会 话 ,会 
话 信息 存储 在 客户 端 计算 机 内 存 中 。 浏 览 器 通过 链接 跳 转 到 网 站 的 其 他 网 页 时 ,保持 会 
话 状态 ,关闭 浏览 器 时 注销 会 话 。 如 果 启 动 会 话 时 设置 了 有 效 期 ,会 话 以 文件 形式 存储 在 
计算 机 硬盘 中 。 启 动 浏览 器 访问 同一 网 站 时 ,恢复 会 话 状态 。 

图 11-1 是 实现 人 才 招聘 网 站 的 会 话 技术 的 基本 原理 。 
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填写 登录 信息 SFZH= 身 份 证 号 ， 
PassWord= 密 码 ， 并 提交 














证 ， 通知 客户 滑 全 全 话 信 自身 
请 求 该 网 站 所 有 网 页 ， 孝 将 传 从 证 二、 密码， 姓名 “各 录 时 间 " 
克 让 信 辣 晤 的 本 本 卫生 的， 二 作 < 和 登录 次 数 ， 返 回 网 页 Index.PHP 
得 录 时 间 ， 春 录 次 数 ， 历 史 和 
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获取 会 话 信 息 身份 证 号 、 密 码 、 
姓名 、 登 录 时 间 ， 登 录 次 数 ， 历 
< 一 史 登 录 时 间 ， 返 回 网 页 
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图 11-1 ”Cookie 会 话 原理 实例 


11.2.2 ”启动 Cookie 会 话 


在 PHP 程序 中 调用 SetCookie 函数 可 以 启动 会 话 。 会 话 信息 以 变量 名 和 值 的 形式 
表示 。 
启动 Cookie 会 话 函 数 
函数 格式 : 
SetCookie (变量 名 [, 值 [, 有 效 时 间 蕉 [, 路 径 [, 域 名 [, 安 全 ]]]]]) 


SetCookie 函数 参数 说 明 如 下 : 

(1) 变量 名 : 系统 通过 变量 进行 会 话 , 会 话 信息 保 存在 客户 端 内 存 或 硬盘 中 ,会 话 期 
间 自 动 封装 到 HTTP 响应 头 部 。 

(2) 值 : 变量 的 值 ,会 话 期 间 与 变量 名 一 起 封装 到 HTTP 响应 头 部 。 在 服务 器 端 可 
以 通过 引用 超 全 局 关联 数组 $_COOKIE[ 变量 名 ' ] 元 素 获取 变量 的 值 。 

(3) 有 效 时 间 戳 : 变量 的 过 期 时 间 戳 ,单位 为 秒 。 当 值 小 于 当前 时 间或 省 略 时 ,变量 
的 生命 周期 为 本 次 浏览 器 会 话 , 保 存在 客户 端 内 存 中 ,关闭 浏览 器 时 注销 变量 。 当 值 大 于 
系统 当前 时 间 时 ,变量 保存 在 客户 端 硬盘 文件 中 ,过 期 时 注销 变量 。 

(4) 路 径 : 变量 有 效 的 服务 器 端 网 站 目录 。 例 如 ,设置 为 /, 在 访问 某 网 站 域名 下 所 
有 网 页 时 ,HTTP 响应 头 部 都 包含 该 变量 及 值 ;设置 为 /ypry/, 仅 在 访问 “ 某 网 站 域名 / 
ypry/" 目录 及 其 子 目录 时 ,HTTP 响应 头 部 包含 该 变量 及 值 ; 默 认为 当前 PHP 程序 所 在 的 
区 作 % 

(5) 域名 : 变量 作用 的 域名 。 例 如 ,使 变量 对 人 才 招 聘 网 站 域名 有 效 , 可 设置 为 


Tczp. com。 
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(6) 安全 : 逻辑 型 ,True 表示 仅 在 使 用 HTTPS 协议 时 才 有 效 ;False 表示 使 用 HTTP 
或 HTTPS 协议 都 有 效 。HTTPS 协议 在 HTTP 协议 基础 上 增加 了 加 密 传 输 功 能 。 


2. 启动 Cookie 会 话 的 注意 事项 


调用 SetCookie 函数 时 应 注意 如 下 两 点 : 

(1) 客户 端 浏览 器 不 能 禁用 Cookie 功能 ; 

(2) Cookie 技术 将 信息 增加 到 HTTP 头 部 ,因此 在 调用 SetCookie( ) 函数 之 前 不 能 向 
客户 端 输出 网 页 内 容 , 如 HTML 标记 等 。 

【 例 11.1】 在 服务 器 端 人 才 招 聘 网 站 目录 下 ,新 建 登 录 网 页 Login11_1. PHP、 登 录 
验证 网 页 LoginCheck11_1. PHP 和 主 网 页 Index11_1. PHP。 将 浏览 器 设置 为 启用 Cookie， 
使 用 浏览 器 依次 访问 Login11_1 、LoginCheck11_1 和 Index11_1 网 页 ,查看 会 话 信息 如 何 通 
过 HTTP 头 部 传递 。 

Login11_1. PHP 网 页 程序 代码 如 下 : 


<HIML > <Head ><Meta Content ="Charset utf -8" ><Title 前 户 登录 </Title ></Head > 
<Body ><Center 亲 户 登录 
<Eorm Name ="LoginFormll 1" Method ="Post" Action ="LoginCheck11 1.PHP" > 
<Table Width ="440" Border ="1" CellSpacing ="0" CellPadding ="1" > 
<TR Align "Center" ><TD > 身份 证 号 </TD > 
<TD > <Input Name ="SFZH" Type ="Text" Size ="18" ></TD></TR> 
<TR Align ="Center" ><TD :密码 </TD> 
<ID > <Input Name ="PassWord" Type ="Password" Size ="18" ></TD></TR > 
<TR Align ="Center" ><TD ColSpan ="2" > 
<Input Type ="Submit" Name ="Button" Value = 提交 "></TD ></TR> 
</Table ></Form></Center ></Body > </HIML > 


LoginCheck11_1. PHP 网 页 程序 代码 如 下 : 


<?PHP 
SSFZH = $Spassword =""; 
If (!Empty($ POST['SFZH'])) $SFZH=$ POST['SFZH']; // 获 取 Loginll 1 中 SFZH 的 值 
IE (!Empty($ POST['PassWord'])) Spassword=$ POST['PassWord']; // 获 取 PassWord 的 值 
$fwq MySQL PConnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select DB('RCZP', $fwq); 
MySQL Query ("Set Names ‘utf8"'"); 
$sql ="'Select 姓名 From ypryb where 身份 证 号 ='". SSFZH."' and 密码 ='". $password."'"; 
// 将 提交 的 身份 证 和 密码 作为 筛选 条 件 , 验 证 用 户 身份 
$rs MySQL Query ( $sql, $fwq) or die (MySQL Error ()) 7 


If (MySQL Num Rows ( Srs) ! -0) // 返回 数据 记录 ,验证 通过 
{ $row MySQL Fetch Assoc( $rs); 
SetCookie ("SFZH", $SFZH) ; // 保存 会 话 信息 身份 证 号 
SetCookie ("PassWord", $password); // 保存 会 话 信息 密码 





SetCookie ("UserName"， $row[" 姓 名 "]); ”// 保存 会 话 信息 姓名 
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} 

Else Echo ' <a href "Loginl1 1.PHP" > 登录 失败 , 单 击 跳 转 到 登录 网 页 。 </a >';?> 
<HIML ><Head ><Meta Charset ="utf -8" ><Title > 登录 验证 Title ></Head> 
<Body ><Center > 
<a href ="Ingex11 1.PHP" > 登录 成 功 , 单 击 跳 转 到 主 网 页 。 </a > 
</Center ></Body > </HIML > 


Index11_1. PHP 网 页 程序 代码 如 下 : 


<HTML > <Head > Meta http Bquiv ="Content -Type" Content ="Text/HIM; CharSet -utf -8"/ > 
<Title > 人 才 招 聘 网 ! </Title ></Head > 

<Body ><Center ><H1 > 人 才 招 聘 < 本 > 

<> 人 Href="ZPGW.PHP " Target =" self" > 招聘 岗位 信息 </A> 

<A Href ="Login11 1.PHP" Target =" self" > 个 人 应 聘 信息 查询 </A> 

< Href ="../BBS/Index.PHP" Target =" self" > 人 才 招 聘 论坛 SA></P> 

</Center ></Body > </HIML > 


启用 Cookie 并 查看 HTTP 头 部 中 传递 的 会 话 信息 ,步骤 如 下 : 
(1) 在 Windows 7 系统 下 启动 IE11 浏览 器 , 单 击 “ 工 具 " 菜 单一 “Internet 选项 ”一 “ 朋 
私 ”" 选 项 卡 ( 如 图 11-2 所 示 ) ,设置 “接受 所 有 Cookie” , 单 击 “ 确 定 ” 按 钮 。 
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图 11-2 浏览 器 启用 Cookie 设置 






























































(2) 在 浏览 器 地 址 栏 输入 HTTP;//localhost/rezp/Login11_1. PHP ,打开 网 页 , 单 击 浏 
览 器 "工具 "菜单 一 "F12 开发 人 员工 具 " 一 网络" 选项 卡 一 “启动 网 络 流量 捕获 "按钮 ， 
如 图 11-3 所 示 。 

(3) 输入 ypryb 表 中 的 身份 证 号 和 密码 , 单 击 *“ 提交 ”按钮 ,在 网 页 LoginCheck11_1 中 
单 击 链接 “登录 成 功 , 单 击 跳 转 到 主 网 页 ”, 跳 转 到 网 页 Indexl1_1。 单 击 * 网 络 " 选 项 卡 中 
的 “详细 信息 "选项 卡 ,查看 “请 求 标 头 " 信息 ,效果 如 图 114 所 示 。 由 于 已 经 启动 会 话 ， 
客户 端 跳 转 到 该 网 站 的 其 他 网 页 时 ,HTTP 请 求 头 部 将 传递 会 话 信息 。 
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图 11-3 启动 网 络 流量 捕获 设置 
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图 114 使 用 HTTP 请 求 头 部 传递 会 话 信息 


(4) 关闭 浏览 器 ,重新 打开 网 页 Index11_1 ,查看 “请 求 标 头 "信息 。 由 于 SetCookie 也 
数 没有 设置 有 效 时 间 戳 的 值 ,在 上 次 关闭 浏览 器 时 ,会 话 信息 被 注销 。 再 次 请 求 时 ,客户 
端 不 再 向 服务 器 发 送 会 话 信息 。 


11.2.3 获取 和 操作 Cookie 会 话 信 息 


在 PHP 程序 中 引用 超 全 局 关联 数组 $_COOKIE 中 的 元 素 可 以 获取 会 话 信 息 ,调用 
SetCookie 函数 能 新 增 ,修改 或 注销 会 话 信息 。 

$ _COOKIE[ ] : 客户 端 以 “变量 名 = 值 ”的 方式 封装 会 话 信息 ,在 PHP 程序 中 使 用 $ 
_COOKIE[ ' 变 量 名 ' ] 获 取 变量 的 值 。 

【 例 11.2】 在 服务 器 端的 人 才 招 聘 网 站 目录 下 ,新 建 登录 网 页 Login11_2. PHP、 登 
录 验 证 网 页 LoginCheck11_2. PHP 和 主 网 页 Index11_2. PHP。 用 户 在 登录 时 ,可 以 选择 登 
录 信 息 的 保存 时 间 。 访问 主 网 页 时 ,如 果 已 保存 登录 信息 , 则 直接 登录 并 显示 会 话 信息 ; 
如 果 未 保存 登录 信息 , 则 显示 登录 网 页 链接 。 

Login11_2. PHP 网 页 程序 代码 如 下 : 
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<HIML ><Head ><Meta Content "CharSet =utf -8" ><Title 前 户 登 录 </Title ></Head> 
<Body ><Center 疹 户 登录 
<Eorm Name ="loginFormll 2" Method="Post" Action =—"LoginCheck1l 2.PHP" > 
<Table Width ="440" Border ="1" CellSpacing ="0" CellPadding ="1" > 
<TR Align "Center" ><TD > 身份 证 号 </TD > 
<TD > <Input Name ="SFZH" Type ="Text" Size 一 18"” ></TD></TR> 
<TR Align ="Center" ><TD :密码 TD> 
<TD > <Input Name ="PassWord" Type ="PassWord" size ="18" ></TD></TR> 
<TR Align ="Center" ><TD > 保存 登录 信息 </TD> 
<TD > <Input Type 2"Radio" Name ="Remeniber" Value ="1" Checked 习 周 
<Input Type ="Radio" Name ="Remeniber" Value ='2" 总 周 
<Input Type ="Radio" Name ="Remeniber" Value 2"3" 冯 周 </TD></TR> 
<TR Align ="Center" ><TD ColSpan 3"2" > 
<Input =="'submit" Name "Button" Value =" 提 交 " ></TD><TR> 
</Table > </Form > </Center > </Body > </HIML > 


LoginCheck11_2. PHP 网 页 程序 代码 如 下 : 


<?PHP 
SSFZH = Spassword =""; Sremenber -0; 
IE (!Empty($ POST['SFZH'])) $SFZH=$ POST['SFZH']; // 获取 Login11 2 中 的 SFEZH 的 值 
If (!Empty($ POST['PassWord'])) Spassword=$ POST['PassWord'];  // 获取 PassWord 的 值 
$fwq MySQL PConnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select db('RCZP', $fwq); 
MySQL Query ("Set Names "utf8°'"); 
$sql] ="Select 姓名 From ypryb where 身份 证 号 ='". SSFZH."' and 密码 ='". $password.""'"; 
Srs MySQL query ( $5ql, $fwq) or die (MYSQL Error ())7 
If (mysql num rows( Srs) ! -0) 
{ $row MySQL Fetch Assoc( $rs); 
If (!Empty($ POST['Remember'])) Sremenriber =$ POST['Remenmber']; 
// 获取 Remember 的 值 
SetCookie ("SFZH", $SFZH, Time () 160* 60 * 24 * 7 * Sremeniber) 7 
// 保存 会 话 信息 身份 证 号 ,根据 Remember 的 值 设置 有 效 时 间 
SetCookie ("PassWord", $password, Time () 60* 60*24*7* Sremember); 
// 保存 会 话 信息 密码 ,根据 Remember 的 值 设 置 有 效 时 间 
SetCookie ("UserName", $row[" 姓 名 "], Time () +160 * 60 * 24 * 7 * S$remenmber); 
// 保存 会 话 信息 姓名 ,根据 Remember 的 值 设置 有 效 时 间 
SetCookie ("LoginNuniber",0,Time () 60* 60 * 24* 7 * Sremeriber); 
//， 保 存 会 话 信息 登录 次 数 ,根据 Remeniber 的 值 设置 有 效 时 间 
Echo ' <a href ="Index11 2.PHP" > 登录 成 功 , 单 击 跳 转 到 主 网 页 。 </a >'; 
} 
Else Echo ' <a href "Login11 2.PHP" > 登录 失败 , 单 击 跳 转 到 登录 网 页 。 </a >'; ?> 
<HIML ><Head > Meta CharSet ="utf -8" ><Title > 登录 验证 </Title ></Head > 
<Body > </Body ></HIML > 
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JIndexl1_2. PHP 网 页 程序 代码 如 下 : 


<HIML > <Head ><Meta HTTP Faquiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8"/ > 
<Title > 人 才 招 聘 网 ! </Title ></Head > 

<Body ><Center ><H1L > 人 才 招 聘 </HL > 

<> 人 Href 二 ZPGW.PHP" Target "self" 洁 聘 岗位 信息 </A> 

<A Href ="Login11 2.PHP" Target =" self" > 个 人 应 聘 信息 查询 </A> 

心 Href 二 ../BBS/Index.PHP" Target =" self"” > 人 才 招 聘 论坛 YA><P> 


<2?PHP 
If (Isset ( $ COOKIE['UserName'])) // 判断 是 否 已 保存 会 话 
{ Echo ' A Href "Logout11 3.PHP" Target =" self" 注销 <A>',' dbr>'; 

Echo ' 用 户 名 : '. $_COOKIE['UserName'],' <br >'; // 显示 用 户 名 


} 
If (Isset ($ COOKIE['LoginNumber"'])) 
{ Echo ' 登 录 次 数 :', $ COOKIE['LoginNumber'] 世 ,' <br >'; ”// 显示 登录 次 数 
SetCookie ('LoginNumber', $ COOKIE['LoginNumber'] #1,Time () H60* 60 * 24*7#*3); 
// 通知 客户 端 登录 次 数 增加 1 
Echo ' 历 史 登 录 时 间 :',' <br >"'; 
$loginNumber =$ COOKIE['LoginNumber"']; 
for( 估 习 ; 匀 <= 氏 oginNumber; 神志 // 循环 输出 用 户 曾经 登录 时 间 
Echo $i,':',date('Y -m-d H:i:s', $ COOKIE[ $$]),' <or >'; 
setcookie( $ COOKIE['LoginNumber'] #1,Time(),Time () {0 * 60 #24*7#*3); 
// 通知 客户 端 保存 本 次 登录 时 间 
Echo $ COOKIE['LoginNumber'] 菇 ,':',date('Y-m-d H:iy' 戌 迅 由 次 登 珊 H 泊 晤 ',，' <br >'; 
} 
Else Echo ' < Href ="Login11 2.PHP" Target =" self" > 请 先 登 录 </A>'; 
// 如 果 未 保存 会 话 信息 ,显示 登录 网 页 超 链接 
?></Center ></Body > </HIML > 
登录 并 查看 会 话 信息 ,步骤 如 下 : 
(1) 使 用 浏览 器 打开 登录 网 页 Login11_2 ,输入 身份 证 号 和 密码 ,保存 登录 信息 选择 
“1 周 ” , 单 击 “ 提 交 ” 按 钮 ,浏览 效果 如 图 11-5 所 示 。 
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图 11-5 ”用 户 登 录 网 页 


(2) 单 击 登录 验证 网 页 LoginCheck11_2 中 的 链接 “登录 成 功 , 单 击 跳 转 到 主 网 页 ”" 跳 
转 到 主 网 页 ,两 次 刷新 主 网 页 后 , 主 网 页 中 显示 会 话 信息 ,如 图 11-6 所 示 。 

(3) SetCookie 函数 设置 的 会 话 信息 保存 在 客户 端 C: \Users \Administrator \AppData 
\Local\Microsoft\Windows \Temporary Internet Files 路 径 下 (Administrator 是 当前 Windows 
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用 户 名 ) ,用 记事 本 程序 打开 rczp/ 文 件 查看 会 话 信息 (记事 本 标题 栏 显示 一 个 临时 的 文 
件 名 ) ,如 图 11-7 所 了 示 。 当 下 次 访问 该 网 站 时 ,客户 端 将 向 服务 器 发 送 会 话 信息 。 






































人 才 招 聘 | zzkrzow.t«t - .. lcs 
招聘 岗位 信息 个 人 应 聘 信息 查询 人 才 招聘 论坛 RE 
注销 SFZH229901199503121538 ~ 
用 户 名 , 刘 德 厚 localhost/rczp/1024 
次 数 ， 163373580830646977 
人 95180162130645569* 
1:2018-02-04 06:49-19 De 4 
2:2018-02-04 06-49-23 163373580830646977 
3:2018-02-04 06:49:24 (本 次 ) 95180162130645569* 2 
图 11-6 主 网 页 显示 会 话 信 息 图 11-7 客户 端 保存 的 会 话 信息 


图 11-7 的 第 一 条 会 话 信 息 中 ,SFZH 表示 会 话 信息 名 称 ,229901199503121538 表示 其 
值 ; localHostrezp/ 表 示 访 问 服务 器 端 目录 或 其 子 目录 时 ,会 话 信息 有 效 ;1024 是 保留 的 
系统 可 选 标志 ;1633735808 表示 过 期 时 间 的 低位 整数 ,30646977 表示 过 期 时 间 的 高 位 整 
数 ,951801621 表示 创建 时 间 的 低位 整数 ,30645569 表示 创建 时 间 的 高 位 整数 ;”* ”表示 
会 话 信息 分 隔 符 。 

可 以 看 出 ,使 用 Cookie 会 话 技术 将 密码 等 敏感 的 用 户 信 息 以 明文 形式 保存 在 客户 
端 ,这 是 很 不 安全 的 。 同 时 ,由 于 会 话 信息 全 部 保存 在 客户 端 , 当 同一 用 户 在 另 一 台 计 算 
机 登录 时 ,会 话 信息 不 能 共享 。 


11.2.4 注销 Cookie 会 话 


在 PHP 程序 中 调用 SetCookie 函数 也 可 以 修改 会 话 变量 的 生命 周期 ,或 在 客户 端 使 
用 浏览 器 的 “清除 上 网 痕迹 "等 工具 ,使 用 手工 删除 Cookie 文件 等 方式 都 可 以 注销 会 话 。 


1. 调用 setCookie 函数 注销 会 话 


调用 setCookie 函数 ,对 会 话 信息 的 有 效 时 间 戳 重新 赋值 ,可 以 注销 会 话 。 
【 例 11.3】 在 服务 器 端 人 才 招 聘 网 站 目录 下 ,设计 网 页 Logout11_3. PHP ,注销 会 话 。 
Logoutl1_3. PHP 网 页 程序 代码 如 下 : 


Logout11 3.PHP 网 页 程序 代码 如 下 : 
<?PHP 
SetCookie ("SFZH", mvTime () 31); 
// 设置 有 效 时 间 小 于 当前 系统 时 间 ,注销 会 话 信息 身份 证 号 

SetCookie ("PassWord", "", Time () 1); // 注销 会 话 信息 密码 
SetCookie ("UserName", "", Time () 41); // 注销 会 话 信息 用 户 名 
$loginNumber =$ COOKIE [ "LoginNumriber ']; 
For (位 习 ;人 久 <= 负 oginNumber; 人 二 和 

SetCookie ("$i","",Time () -1); // 循环 注销 会 话 信 息 i (登录 时 
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的 


间 ) 
SetCookie ("LoginNumber", "", Time () 141); // 注销 会 话 信息 登录 次 数 
2 
<HIML ><Head > Meta CharSet "utf -8" ><Title 注销 </Title ></Head > 
<Body > Center ><a href "Index11 2.PHP" 注销 成 功 , 单 击 跳 转 到 主 网 页 </a> 
</Center ></Body ></HIML > 


使 用 浏览 器 访问 网 页 Index11_2, 单 击 链 接 “ 注 销 ” ,在 网 页 Logout11_3 中 单 击 链接 
“注销 成 功 , 单 击 跳 转 到 网 站 首页 ” ,会 话 信息 已 注销 , 主 网 页 不 再 显示 相关 内 容 。 


2. 通过 工具 注销 会 话 


在 客户 端 使 用 浏览 器 的 “删除 Cookie “清除 历史 记录 "或 “清除 上 网 痕迹 ”等 工具 ,可 
以 注销 会 话 信息 ,如 图 11-8 所 示 。 此 外 ,手工 删除 客户 端 硬盘 上 的 Cookie 文件 也 可 以 注 
销 会 话 信息 。 
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图 11-8 使 用 浏览 器 注销 会 话 信息 


11.3 Session 会 话 技 术 


由 于 Cookie 会 话 技术 具有 会 话 信息 存储 量 小 .网 络 传输 数据 量 大 和 不 安全 等 缺陷 ， 
目前 大 多 数 网 站 都 使 用 Session 会 话 技术 。 

使 用 Session 会 话 技 术 , 客 户 端 浏览 器 需要 启用 Cookie ,服务 器 端 需要 设置 会 话 参 数 
和 启动 会 话 。 启 动 会 话 有 程序 启动 和 系统 自动 启动 两 种 方式 。 
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11.3.1 Session 会话 技术 主要 环节 


Session 会 话 技术 由 服务 器 端 启 动 会 话 并 发 送 会 话 标识 符 (默认 为 PHPSESSID ) 和 值 ， 
在 指定 路 径 ( 系统 默认 是 …\XAMMP\TMP\ ) 创建 以 “sess_”+ “会 话 标识 符 值 ” 命 名 的 
Session 文件 。 在 会 话 过 程 中 ,客户 端 需要 保存 并 发 送 的 会 话 信息 仅 是 会 话 标识 符 和 值 ， 
会 话 其 他 信息 保存 在 服务 器 端的 Session 文件 中 。 在 PHP 程序 中 可 以 使 用 超 全 局 关联 数 
组 获取 会 话 信息 。 


1. 设置 Session 会 话 参 数 


通过 修改 Apache 服务 器 的 PHP. INI 文件 设置 Session 会 话 参 数 , 与 Session 会 话 相 关 
的 选项 如 下 。 

(1) Session. Use_Cookies: 指定 客户 端 是 否 使 用 Cookie 技术 保存 会 话 标识 符 , 默 认 值 
为 1 ,表示 使 用 Cookie 保存 会 话 标识 符 。 

(2) Session. Name: 指定 会 话 标识 符 名 ,默认 值 为 PHPSESSID 。 

(3) Session. Cookie_LifeTime: 指定 会 话 标识 符 在 客户 端的 过 期 时 间 ,单位 为 秒 。 默 
认 值 为 0, 表示 会 话 标 识 符 生命 周期 为 一 次 浏览 器 会 话 , 关 闭 浏览 需 窗 口 时 注销 ; 当 值 大 
于 0 时 ,会 话 标识 符 保 存在 客户 端 硬盘 中 ,过 期 时 注销 。 

(4) Session. CC_MaxLifeTime: 指定 会 话 信息 在 服务 器 端的 过 期 时 间 ,单位 为 秒 ,过 
期 时 注销 。 

(5) Session. Save_Path: 指定 会 话 信息 在 服务 器 端的 存储 路 径 , 默 认 值 为 XAMPP 安 
装 路 径 下 的 Tmp 目录 。 

(6) Session. Auto_Start: 指定 是 否 自动 启动 会 话 ,默认 值 为 0, 表 示 不 自动 启动 会 话 ; 
当 值 为 1 时 ,系统 自动 启动 会 话 。 

(7) Session. GC_Probability 和 Session. GC_Divisor: 指定 服务 器 端 每 次 调用 Session_ 
Start 函数 或 自动 启动 会 话 时 ,启动 垃圾 回收 进程 的 概率 。 垃 圾 回收 进程 用 于 扫描 并 删除 
会 话 信息 存储 路 径 下 所 有 的 过 期 会 话 文件 ,启动 概率 = Session. GC_Probability /Session. 
GC_Divisor。 例 如 Session. GC_Probability 指定 为 1 ,Session. GC_Divisor 指定 为 10, 表 示 服 
务 器 端 每 次 调用 Session_Start 函数 或 自动 启动 会 话 时 ,有 10% 的 概率 启动 垃圾 回收 进程 。 


2. 启动 Session 会 话 


有 如 下 两 种 方式 启动 会 话 。 

(1) 程序 启动 会 话 方式 : 客户 端 通过 表单 网 页 等 向 服务 器 提交 信息 (如 身份 证 号 和 
密码 等 ) ,由 服务 器 验证 信息 正确 性 ,并 确定 是 否 需要 启动 会 话 。 如 果 需 要 启动 会 话 , 则 
服务 器 端 调用 启动 会 话 函数 ,将 值 唯一 的 会 话 标识 符 通 过 HTTP 响应 头 部 发 送 给 客户 端 ， 
并 在 指定 文件 夹 中 创建 以 *sess ”+ “会 话 标识 符 " 命 名 的 Session 文件 。 客 户 端 浏览 器 收 
到 会 话 标识 符 后 ,使 用 Cookie 技术 将 会 话 标识 符 存储 到 本 地 ,完成 启动 会 话 。 

(2) 系统 自动 启动 方式 : 服务 器 在 第 一 次 响应 客户 端 请 求 时 自动 启动 会 话 。 
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3. 获取 Session 会 话 信息 


如 果 会 话 信息 存在 ,客户 端 向 服务 器 发 送 请 求 时 ,将 会 话 标识 符 和 值 添加 到 HTTP 请 
求 头 部 ,服务 器 根据 收 到 的 会 话 标识 符 值 找到 本 地 对 应 的 Session 文件 ,并 从 文件 中 取出 
会 话 的 其 他 信息 ,恢复 会 话 状态 。 


4. 新 增 或 修改 Session 会 话 信息 
服务 器 端 将 需要 新 增 或 修改 的 会 话 信 息 存 储 到 对 应 的 Session 文件 中 。 
5. 注销 Session 会 话 信息 


以 下 三 种 情况 将 注销 会 话 : 

(1) 当 会 话 生命 周 期 为 一 次 浏览 器 会 话 时 ,客户 端 关 闭 浏 览 器 窗口 。 

(2) 当 会 话 生命 周期 为 长 期 时 ,会 话 过 期 。 

(3) 在 程序 中 调用 PHP 相关 函数 。 

Session 技术 通常 用 于 保存 会 话 过 程 中 频繁 使 用 的 身份 和 登录 状态 等 信息 。 例 如 ,用 
户 登录 网 站 时 ,系统 可 以 通过 查询 数据 库 表 获 取 用 户 身 份 、 系 统 访问 和 操作 权限 等 信息 。 
如 果 每 次 网 页 跳 转 都 需要 查询 数据 库 表 , 则 会 增加 数据 库 的 负担 ,此 时 可 以 使 用 Session 
技术 保存 有 关 信 息 。 


11.3.2 程序 启动 Session 会 话 


启动 会 话 时 创建 会 话 标识 符 , 在 PHP 程序 中 通过 调用 函数 可 以 创建 ,设置 和 获取 会 
话 标识 符 。 


1. 程序 启动 Session 会 话 


在 系统 默认 状态 下 ,PHP. INI 文件 中 Session. Auto_Start 选项 的 值 为 0, 表示 不 自动 启 
动 会 话 , 此 时 需要 在 PHP 程序 中 调用 Session_Start 函数 启动 会 话 。 
函数 格式 : 


Session Start () 


在 程序 启动 会 话 方 式 下 ,每 个 使 用 Session 会 话 技术 的 PHP 程序 文件 中 都 必须 调用 
Session_Start 函数 ( 仅 一 次 ) 启 动 会 话 ,创建 和 装载 会 话 超 全 局 关联 数组 $_SESSION ,执行 
成 功 后 函数 返回 逻辑 值 为 True。 在 系统 启动 会 话 方式 下 ,PHP 程序 中 不 能 调用 该 函数 。 

Session_ID 和 Session_Start 函数 配合 ,可 以 在 创建 会 话 时 自 定 义 会 话 标识 符 ,用 户 登 
录 某 网 站 首次 调用 Session_Start 函数 时 ,如 果 没 有 调用 Session_ID 函数 设置 自 定义 会 话 标 
识 符 , 则 系统 自动 分 配 会 话 标识 符 ( 与 系统 启动 会 话 方式 相同 ) 。 

在 每 次 (包括 首次 ) 调 用 Session_Start 函数 时 ,如 果 对 应 的 会 话 标识 符 在 Web 服务 器 中 
不 存在 , 则 系统 自动 产生 会 话 文件 (系统 默认 是 …\XAMMP\TMP\SESS_< 会 话 标 识 符 > ) ， 
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创建 空 的 超 全 局 关联 数组 $ _SESSION ;如 果 对 应 的 会 话 标识 符 在 Web 服务 器 中 已 经 存在 ， 
则 用 会 话 文件 的 内 容 装 载 超 全 局 关联 数组 $_SESSION ,继承 之 前 会 话 的 相关 信息 。 

在 每 个 调用 Session_Start 函数 的 PHP 程序 文件 中 ,都 可 以 定义 超 全 局 关联 数组 $_ 
SESSION 中 的 元 素 ,改变 或 引用 元 素 的 值 ,实现 向 其 他 PHP 程序 文件 传输 数据 或 接收 其 
他 PHP 程序 文件 传 来 的 数据 。 


2. 设置 和 获取 Session 会 话 标 识 符 


每 个 Session 会 话 都 有 会 话 标识 符 ,其 名 系统 默认 为 PHPSESSID, 可 以 在 PHP. INI 中 
修改 。 只 要 PHP 程序 中 会 话 标识 符 相 同 , 它 们 就 对 应 同一 个 会 话 超 全 局 关联 数组 $_ 
SESSION ,由 此 可 以 实现 多 个 会 话 之 间 的 数据 传递 。 在 程序 启动 会 话 方式 下 ,调用 Session 
_ID 函数 可 以 自 定义 会 话 标识 符 。 

函数 格式 : 

Session ID([ 自 定义 会 话 标识 符 ]) 

调用 该 函数 时 返回 当前 的 会 话 标识 符 , 当 前 还 没有 启动 会 话 时 ,函数 的 返回 值 为 空 串 
(长 度 为 0) 。 如 果 调 用 此 函数 时 有 参数 , 则 为 会 话 自 定义 标识 符 。 

会 话 标识 符 在 客户 端 以 字符 形式 保存 在 存储 器 中 , 当 访 问 相 应 网 站 时 ,客服 端 向 服务 
器 发 送 会 话 标识 符 ; 会 话 标识 符 在 服务 器 端 作为 文件 名 的 一 部 分 , 当 服 务 器 收 到 客户 端 发 
送 的 会 话 标识 符 时 ,查找 相应 文件 ,取出 会 话 的 相关 信息 。 

以 人 才 招 聘 网 站 为 例 ,如 果 两 个 用 户 使 用 相同 的 自 定义 会 话 标识 符 , 则 他 们 共享 服务 
器 端 同 一 会 话 文件 的 内 容 , 实 现 了 多 用 户 共 享 会 话 信息 。 

自 定义 会 话 标 识 符 需要 调用 Session_ID 函数 后 再 调用 Session_Start 函数 启动 会 话 。 

【 例 11.4】 在 服务 器 端 人 才 招 聘 网 站 目录 下 ,新 建 登录 网 页 Login11_4. PHP 登录 
验证 网 页 LoginCheck11_4. PHP 和 主 网 页 Index11_4. PHP。 用 户 在 登录 时 ,可 以 选择 是 否 
保存 登录 信息 ;登录 验证 时 ,将 身份 证 号 作为 会 话 标识 符 ; 访 问 主 网 页 时 ,可 以 使 用 不 同 的 
客户 端 计算 机 共享 会 话 信息 ,如 果 服 务 器 端 已 保存 登录 信息 , 则 直接 登录 并 显示 会 话 信 
息 ; 如 果 服 务 器 端 未 保存 登录 信息 , 则 仅 显示 登录 网 页 的 链接 。 

在 配置 文件 PHP. INI 中 设置 





Session.Use Cookies -1; // 指 定 客 户 端 使 用 Cookie 技术 保存 会 话 标识 符 
Session.Cookie LifeTime =864000; // 指 定 会 话 标识 符 在 客户 端的 生命 周期 为 一 天 
Session.GC MaxLi feTime =86400; // 指 定 会 话 信息 在 服务 器 端的 生命 周期 为 一 天 


保存 设置 后 ,重启 Apache 服务 。 
设计 Login11_4. PHP 网 页 程序 代码 如 下 : 
<HIML ><Head ><Meta Content "CharSet =utf -8" ><Title 前 户 登 录 </Title ></Head > 
<Body ><Center 肖 户 登录 
<Eorm Name ="loginFormll 4" Method ="Post" Action ="LoginCheck11 4.PHP" > 
<Table Width ="440" Border ="1" CellSpacing ="0" CellPadding =3"1" > 
<IR Align "Center" ><TD > 身份 证 号 </TD > 
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<ID > <Input Name ="SFZH" Type —"Text" Size 3"18" ></TD></TR> 
<TR Align =Center" ><TD :密码 人 ID> 
<ID > <Input Name ="PassWord" Type ="PassWord" Size 3"18" ></TD ></TR> 
<TR Align "Center" ><TD > 保存 登录 信息 </TD> 
<ID > <Input Type ="Radio" Name ="Remenber" Value = 1" Checked 间 
<Input Type ~"Radio" Name ~"Remember" Value =2" 辣 </TD></TR> 
<IR Align ="Center" > 
<TD ColSpan 3"2" ><Input Type "submit" Name ="Button" Value 二 提交 "></TD ></TR> 


</Table ></Form></Center > </Body > </HIML > 


LoginCheck11_4. PHP 网 页 程序 代码 如 下 : 


<?2PHP 

SSFZH = Spassword =""; 

S$remember 0; 

If (!Empty($ POST['SFZH'])) $SFZH=$ POST['SFZH'];  // 获取 Login11 4 中 SFZH 的 值 

If (!Empty($ POST['PassWord'])) Sbassword=$ POST['PassWord'];  // 获取 PassWord 的 值 


$fwq MySQL PConnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select db('RCZP', $fwq); 
MySQL Query ("Set Names ‘utf8'"); 
$sql ="'Select 姓名 From ypryb where 身份 证 号 ='". $SSFZH."" and 密码 ="'". Spassword." "7 
// 将 提交 的 身份 证 和 密码 作为 筛选 条 件 , 验 证 用 户 身份 
Srs -MySQL query ( $sql, $fwq) or die (MySQL Error()); 


If (mysql_num rows ( $rs) ! -0) // 返回 数据 记录 ,验证 通过 
{ If($ POST['Remember'] = 导 ) // 如 果 选 择 “ 保 存 登 录 信 息 ” 
{ Session ID(" $5FZH"); // 设置 会 话 标识 符 为 身份 证 号 
Session Start (); // 启动 以 身份 证 号 为 标识 符 的 会 话 ,创建 或 装载 数组 $ SESSION 
$row -MySQL Fetch Assoc( $rs); 
If(!Isset ($ SESSION['SFZH'])) $ SESSION["SFZH'] =$SFZH; // 保存 身份 证 号 
If(!Isset($ SESSION['PassWord'])) $ SESSION['PassWord'] =$password; 
// 保存 密码 
If(!Isset ($ SESSION['UserName'])) $ SESSION['UserName'] =$row[" 姓 名 "]; 
// 存 姓名 
If(!Isset ($ SESSION['LoginNumber'])) $ SESSION['LoginNumber'] -0; 
// 存 登 录 次 数 


} 

Echo ' <a href "Index11 4.PHP" > 登录 成 功 , 单 击 跳 转 到 主 网 页 。 </a >'; 

} 
Else Echo ' <a href "Login11 4.PHP" > 登录 失败 , 单 击 跳 转 到 登录 网 页 。 </a >';? > 
<HIML > <Head ><Meta CharSet ="utf -8" ><Title 3 登录 验证 </Title ></Head > 
<Body > </Body ></HIML > 


Index11_4. PHP 网 页 程序 代码 如 下 : 


<HIML > <Head > Meta HTTP Fiquiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8"/> 


(400 基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


<Title > 人 才 招 聘 网 ! </Title ></Head > 
<Body ><Center ><H1 > 人 才 招 聘 <w/HL > 
< > 人 Href "2PGW.PHP " Target =" self" > 招聘 岗位 信息 </R> 
<A Href ="Login11 4.PHP" Target =" self" > 个 人 应 聘 信息 查询 </A> 
< Href 一. ./BBS/Index.PHP" Target =" self" > 人 才 招聘 论坛 YA><P> 
<?PHP 
Session Start (); 
If (Isset ( $ SESSION['UserName'])) // 判断 是 否 已 保存 会 话 信息 用 户 名 
{ Echo ' 人 Href ="Logout11 8.PHP" Target =" self" 注销 </A>',' qr>'; 
Echo ' 用 户 名 : '. $ SESSION['UserName'],' <br >'; // 显示 会 话 信息 用 户 名 
} 
If (Isset ($ SESSION['LoginNumber"'])) 
{  $ SESSION['LoginNumber'] =$ SESSION['LoginNumber'] #1; // 会 话 信息 登 录 次 数 增加 1 
Echo ' 登 录 次 数 :',$_SESSION['LoginNumber'],' <br >'; ”// 显示 会 话 信息 登录 次 数 
$loginNunmber ='Log'. $ SESSION['LoginNumber']; 
$_SESSION[" $loginNumber"] -Time (); // 注册 会 话 数组 元 素 ,保存 本 次 登录 时 间 
Echo ' 历 史 登 录 时 间 :"',"' <br >'; 
for( 人 名 习 ; 久 <=$ SESSION['LoginNumber']; 久 ++4) 
Echo $i,':',date('Y -m-d H:i:s', $ SESSION['Log'. $$]),' <or>'; 
// 循环 输出 用 户 所 有 的 登录 时 间 
} 
Else Echo ' < Href ="Login11 4.PHP" Target ~" self" > 请 先 登 录 </A>'; 
// 未 保存 会 话 信息 ,显示 登录 网 页 链接 
?></Center ></Body > </HIML > 
登录 并 查看 会 话 信息 ,步骤 如 下 : 
(1) 使 用 浏览 器 打开 登录 网 页 Login11_4, 输 入 身份 证 号 和 密码 ,保存 登录 信息 选择 
“是 ” , 单 击 “提交 ”按钮 ,浏览 效果 如 图 11-9 所 示 。 
(2) 单 击 登录 验证 网 页 LoginCheck11_4 中 的 链接 “登录 成 功 , 单 击 跳 转 到 主 网 
页 " 跳 转 到 主 网 页 ,再 次 刷新 主 网 页 后 , 主 网 页 中 显示 会 话 信息 ,浏览 效果 如 图 11-10 
所 示 。 


人 才 招 聘 


招聘 岗位 信息 个 人 应 聘 信息 查询 人 才 招 聘 论坛 
































用 户 登 录 注销 
身份 证 号 229901199503121538 用 户 名 : 刘 德 厚 
本 二 i 
= 录 时 间 : 
保存 登录 信息 @ 是 O 否 1:2018-02-03 22:57:38 
提交 | 2:2018-02-03 22:57:40 
图 11-9 ”用户 登录 网 页 图 11-10 主 网 页 显示 会 话 信息 


(3) 用 记事 本 程序 打开 客户 端 计 算 机 C:\Users \ Administrator \ AppData \ Local \ 
Microsoft\Windows\Temporary Internet Files 路 径 下 (Administrator 是 当前 Windows 用 户 名 ) 
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的 Cookie:administrator@ localhost 文件 ,查看 客户 端 保存 的 会 话 信 息 , 如 图 11-11 所 示 。 
(4) 用 记事 本 程序 打开 服务 器 的 …\ XAMMP \ TMP\ 路径 下 的 文件 sess _ 
229901199503121538 ,查看 服务 器 端 保存 的 会 话 信息 ,如 图 11-12 所 示 。 











PHPSESSID zH1 
229901199503121538 区 介 “229901199503121538” pessmord| 国 
localhost/1024 | a:4: 1 :Uoerens le:S; ;信德 
212710361630645704 i i 
141932536930645503* 








图 11-11 客户 端 保存 的 会 话 信息 图 11-12 ”服务 器 端 保存 的 会 话 信息 


服务 器 端 以 "变量 名 1 数据 类 型 :长 度 : 值 " 的 格式 保存 会 话 信息 ,会 话 信息 生命 周期 
在 PHP.INI 文 件 中 统一 定义 。 由 于 会 话 信息 an 中 自 定义 会 话 
标识 符 为 身份 证 号 ,同一 用 户 在 不 同 客户 端 登录 时 ,将 共享 会 话 信息 。 

【 例 11.5】 在 程序 ee Index11_5. PHP, 输 出 网 
页 最 近 访问 时 间 和 访问 总 次 数 , 浏 览 效 果 如 图 11-13 所 示 。 


人 才 招 聘 


招聘 岗位 信息 个 人 应 聘 信息 查询 人 才 招 聘 论坛 


最近 光疗 时 间 。 2018-01-21 12:19:32 
访问 总 次 数 ，3 








图 11-13” 主 网 页 显示 会 话 信息 


Index11_5. PHP 网 页 程序 代码 如 下 : 


<HIML ><Head ><Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8"/ > 
<Title > 人 才 招 聘 网 ! </Title ></Head ><Body > 

<H1 > 人 才 招 聘 < 本 > 

<> 人 Href="ZPGW.PHP " Target =" self" > 招聘 岗位 信息 </A> 

< Href ="Login11 6.PHP" Target = self" > 个 人 应 聘 信息 查询 </A > 

<A Href 二../BBS/Index.PHP" Target =" self"” > 人 才 招 聘 论坛 YA></P> 


<?PHP 
Session ID('RCZP'); // 访问 者 都 用 相同 的 会 话 标识 符 RCZzP, 以便 共享 会 话 信息 
Session Start () 7 // 启动 以 RCZP 为 标识 符 的 会 话 ,创建 或 装载 数组 $ SESSION 


IfE(!Isset ( $ SESSION[ "访问 总 次 数 '])) $ SESSION[ "访问 总 次 数 "] -0; 

$ SESSION[ "访问 总 次 数 '] =$ SESSION[ "访问 总 次 数 '] 电 ; 

If (Isset ( $_ SESSION[' 最 近 访 问 时间 '])) 

Echo ' 最 近 访问 时 间 :',$_SESSION[' 最 近 访问 时 间 "],' <br > 

Echo ' 访 问 总 次 数 :',$_SESSION[' 访 问 总 次 数 '],' <br > 

Date Default Timezone Set('PRC'); // 设置 北京 时 间 
$_SESSION[' 最 近 访 问 时 间 '] Pate("Y-m-d h:i:s"); 

?></Body ></HIML > 


访问 此 网 页 时 ,如 果 Web 服务 器 中 没有 文件 SESS_RCZP (系统 默认 路 径 是 …\ 
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XAMMP\TMP\) , 则 系统 自动 创建 该 会 话 文件 ,在 一 段 时 间 内 (时 间 长 短 取 决 于 Web 服务 
器 设置 的 会 话 生 命 周期 ) ,所 有 用 户 可 以 访问 该 文件 ,装载 .修改 和 引用 超 全 局 关联 数组 
$_SESSION 中 的 元 素 $_SESSION [访问 总 次 数 '] 和 $_SESSION[ "最近 访问 时 间 ' ] , 实 
现 数据 传递 。 

单 击 “招聘 岗位 信息 "链接 执行 ZPGW. PHP 时 ,调用 Session_Start 函数 ,启动 以 RCZP 
为 标识 符 的 会 话 , 装 载 超 全 局 关联 数组 $ _SESSION ,ZPGW 网 页 ,如 图 11-14 所 示 。 
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图 11-14 招聘 岗位 网 页 显示 会 话 信息 


ZPGW. PHP 程序 代码 如 下 : 


<?PHP 
Session Start (); 
// 启动 以 RCZP 为 标识 符 的 会 话 
Echo ' 本 次 登录 时 间 :',$_SESSION[' 最 近 访问 时 间 '],' <br >'; 
$fwq MySQL PConnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select db('RCZP', $fwq); 
MySQL Query ("Set Names ‘utf8"'"); 
$sql ="Select 岗位 编号 ,岗位 名 称 ， 
ELT (最 低 学 历 , ' 无 ',' 专 科 ', "本 科 …， "研究 生 … ' 博 士 ') as 学 历 要 求 ， 
ELT (最 低 学 位 , ' 无 ',' 学 士 ', ' 双 学 士 ', "硕士 "博士 ') Rs 学 位 要 求 ， 
人 数 ,年 龄 上 限 ,年 薪 , 笔 试 成 绩 比 例 , 笔 试 日 期 ,聘任 要 求 ,公司 名 称 From gwb"; 
Srs -MySQL query ( $sql, $fwq) or die (MySQL Error()); 
$row MySQL Fetch Assoc( $rs); ?> 
<HIML ><Head > 
<Meta HTTP Equiv ="Content -Type" Content ="Text/HIML; CharSet autf -8" /> 
<Title > 人 才 招 聘 岗位 信息 发 布 Title ></Head > <Body > 
<Table Border ="1" ><Caption Style 2"'Font -Size:24px" > 人 才 招 聘 岗 位 信息 表 </Caption > 
<IR ><TH 疯 位 编号 <TH 疯 位 名 称 <TH 阅历 要 求 <TH 郑 位 要 求 <rH > 人 数 <TH > 年 龄 上 限 <rH > 


年 薪 


// 接收 其 他 程序 传输 的 数据 


<IH 准 试 成 绩 比 例 <rH 兹 试 日 期 ATH 珊 任 要 求 <rH > 公司 名 称 </TR> 


<?PHP do { ?> 
<IR><ID ><?PHP Echo $row[' 岗 位 编号 ']; ?><TD ><?PHP Echo $row[' 岗 位 名 称 ']; ?> 
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<TD ><?PHP Echo $row[' 学 历 要 求 ']; ? ><TD ><?PHP Echo $row[' 学 位 要 求 ']; ?> 
<TD ><?PHP Echo $row[' 人 数 ']; ?><TD ><?PHP Echo $row[' 年 龄 上 限 ']; ?> 
<TD ><?PHP Echo $row[' 年 薪 ']; ?><TD ><?PHP Echo $row[' 笔 试 成 绩 比 例 ']; ?> 
<TD ><?PHP Echo $row[' 笔 试 日 期 ']; ? ><TD ><?PHP Echo $row[' 聘 任 要 求 ']; ?> 
<TD ><?PHP Echo $row[' 公 司 名 称 ']; ?></TR> 

<?PHP } While ( $row -MySQL Fetch Assoc( $rs)); ?> 

</Table ></Body > </HIML > 


为 了 在 Index11_5. PHP 中 通过 链接 能 正常 执行 Login11_6. PHP 和 SBKH. PHP, 还 需 
要 将 这 两 个 程序 中 的 代码 “//Session_Start( ) " 改 为 “Session_Start( ) ;” , 即 , 删 掉 注释 标记 
“//” ,使 之 能 通过 程序 启动 标识 符 为 RCZP 的 会 话 。 


11.3.3 ”系统 启动 Session 会 话 


PHP. INI 文件 中 Session. Auto_Start 选项 值 为 1 ,表示 系统 自动 启动 Session 会 话 。 当 
用 户 首次 访问 某 网 站 时 , Web 服务 器 自动 为 该 用 户 分 配 会 话 标识 符 、 创 建 会 话 文件 和 启 
动 会 话 。 此 后 ,在 会 话 生 命 周期 内 ,用 户 访问 该 网 站 时 都 使 用 此 会 话 标识 符 , 即 ,可 以 注 
册 修改 和 引用 同一 个 超 全 局 关联 数组 $_SESSION 中 的 元 素 , 以 便 实现 PHP 程序 之 间 的 
数据 传递 。 

如 果 使 用 了 系统 自动 启动 会 话 , 不 能 在 程序 中 调用 session_start 函数 ,但 是 仍然 可 以 
使 用 Session_ID 函数 设置 会 话 标识 符 。 

【 例 11.6】 在 系统 启动 会 话 的 前 提 下 ,设计 应 聘 人 员 登 录 网 页 Login11_6. PHP ,验证 身 
份 证 号 和 密码 正确 后 ,通过 链接 跳 转 到 SBKH. PHP 网 页 ,查看 本 人 申报 岗位 及 考核 信息 。 

Login11_6. PHP 程序 代码 如 下 : 


<HIML ><Head > Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8"/ > 
<Title > 永 聘 人 员 登 录 </Title ></Head > 
<Body > 
<Eorm Name ="LoginF™" Method ="Post" Action ="" > 
< 心 痊 份 证 号 : <Input Name ="'sfzh" Type ="Text"/ ><P/ > 
也 北 码 : <Input Name =mm" Type ="PassWord" / ><P/ > 
< ><Input Type ="Submit" Name ="dl" Value 二 登录 "/ ></P></Formn> 
<2PHP 
If (Isset ($ POST['d1'])) 
{ $sfzh =$ POST['sfzh']; 
If (StrLen (Trim( $sfzh)) <L8) Die(' 身 份 证 号 太 短 !'); 
Sm =$ POST[ mm']; 
// Session Start(); /* 系统 自动 启动 会 话 , 不 再 需要 程序 启动 会 话 * / 
Sconn MySQL PConnect ("LocalHost", "ywy"，"ywy211") 7/ 连接 服务 器 
If(! Sconn) Die (" 连 接 数据 库 失 败 : ".Mysql Error ()); 
MySQL Select DB('rczp', $conn); // 选择 数据 库 
MySQL Query ("Set Names "utf8°'"); 
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$sql "Select 姓名 From ypryb Where 身份 证 号 =' Ssfzh' and 密码 =' Sm'"7 


// 检验 身份 证 号 及 密码 是 否 正确 
Srs MySQL Query ( $sql, $conn) or Die (mysql error ()) 7 
If( $result -MySQL Fetch Rssoc( Srs)) // 记录 集 非 空 , 则 登录 成 功 
{ $ SESSION[ "身份 证 号 '] =$sfzh; // 注册 会 话 数组 元 素 ,保存 身份 证 号 
$ SESSION[ "姓名 '] =Sresult[" 姓 名 ']7 // 注册 会 话 数组 元 素 ,保存 姓名 
$_SESSION[' 密 码 '] =Smmz // 注册 会 话 数组 元 素 ,保存 密码 


} 

Else Die ( $sfzh.' :登录 失败 !1'); 

Echo $ SESSION[' 姓 名 '"], "欢迎 您 访问 人 才 招聘 网 ! <br >'; 

Echo ' 可 以 查看 本 人 <A href "SBKH.PHP" > 申报 考核 </RA 六 息 '; 
} ?></Body ></HIML > 


程序 中 注册 $_SESSION[' 身 份 证 号 ' ] 和 $_SESSION[' 姓 名 ' ] 两 个 超 全 局 关联 数组 
元 素 , 用 于 向 SBKH. PHP 中 传递 数据 。 

Login. PHP 中 通过 链接 ( < A href = "SBKH. PHP" > 申报 考核 </A > ) 执行 SBKH. 
PHP 时 ,引用 了 $$_SESSION[' 身份 证 号 ' ] 和 $_SESSION[' 姓 名 ' ] 两 个 元 素 ,SBKH. PHP 
程序 代码 如 下 : 


<?PHP 
// Session Start () 7 /* 系统 启动 会 话 ,不 再 需要 程序 启动 会 话 * / 
Sfwq MySQL PConnect ("LocalHost", "ywy", "ywy211"); 
MySQL Select DB('rczp', $fwq); 
MySQL Query ("Set Names "utf8"") 7 
$sfzh =$_SESSION[' 身 份 证 号 ']; // 引用 超 全 局 关联 数组 元 素 身 份 证 号 的 值 
$sql] ="Select 岗位 编号 , 岗位 名 称 ,If (资格 审核 , "通过 ', "未 过 ') as 资格 ,笔试 成 绩 ， 
面试 成 绩 From GWB Natural Join GWCJB "; 
$sql =$sql." Where 身份 证 号 =' $sfzh'"; 
$rs -MySQL Query ( $sql, $fwq) or die (mysql] error()); 
$row MySQL Fetch Assoc( $rs); ?> 
<HIML ><Head > Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8" / 
. 
<Title > 个 人 申报 信息 </Title ></Head > 
<Body ><Center > <Table Border ="1" ><Caption style ="Font -Size:24px" > 
<?PHP Echo $ SESSION[' 姓 名 ']; // 引用 超 全 局 关联 数组 元 素 姓名 的 值 
?> 
本 人 申报 考核 信息 表 </Caption > 
<TR ><TH 疯 位 编号 <TH 疯 位 名 称 <IH 资格 <TH 次 试 成 绩 <rH > 面试 成 绩 </TR > 
<?PHP do { ?> 
<TR ><TD ><?PHP Echo $row[' 岗 位 编号 ']; ?> 
<TD ><?PHP Echo $row[' 岗 位 名 称 ']; ?> 
<TD ><?PHP Echo $row[' 资 格 ']; ?> 
<TD ><?PHP Echo $row[' 笔 试 成 绩 ']; ?> 
<TD ><?PHP Echo $row[' 面 试 成 绩 ']; ?></TR > 


<?PHP } While ( $row -MySQL Fetch Assoc( $rs)); ?> 
</Table ></Center ></Body ><VHITML > 


SBKH 网 页 浏览 效果 如 图 11-15 所 示 。 
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图 11-15 申报 考核 网 页 显示 会 话 信 息 


【 例 11.7】 将 例 11.6 改 成 以 系统 或 程序 启动 会 话 方式 都 能 正常 运行 的 程序 , 当 用 
程序 启动 会 话 方式 时 ,以 应 聘 人 员 的 身份 证 号 为 会 话 标识 符 值 ,以 便 此 应 聘 人 员 多 次 访问 
该 Web 服务 器 时 都 使 用 同一 个 会 话 ,减少 通过 数据 库 验 证 其 身份 的 次 数 。 

改进 Login11_6. PHP 后 的 Login11_7. PHP 程序 代码 如 下 : 


<HIML ><Head > Meta HTTP Fiquiv ="Content -Type" Content ="Text/HIML; CharSet =utf -8"/ > 
<Title > 应 聘 人 员 登 录 </Title ></Head > 
<Body > om Name ="LoginF" Method ="Post" Action 二 '" > 
< 将 份 证 号 : <Input Name ="'sfzh" Type ="Text"/ ><P/ > 
也 浪 码 : <Input Name = mm" Type ="PassWord" / ><P/ > 
< 了 ><Input Type ="Submit" Name ="dl" Value =" 登录 "/ ><P></Form> 
<?PHP 
If (Isset ($ POST['d1'])) 
{ S$sfzh =$ POST['sfzh']; 
If (StrLen (Trim( $sfzh)) <8) Die(' 身 份 证 号 太 短 !'); 
Sam =$ POST[ mm"']; 


// 增加 的 代码 段 
If (StrLen (Session ID()) =-=0) ”// 分 析 是 系统 或 程序 启动 会 话 方式 
{ Session ID( $sfzh); // 程序 启动 会 话 方式 ,设置 身份 证 号 为 会 话 标识 符 
Session Start (); // 启动 以 身份 证 号 为 标识 符 的 会 话 


} 

If(!Isset($ SESSION[' 身 份 证 号 ']) Or !Isset ($_ SESSION[' 密 码 ']) Or 

$_SESSION[' 身 份 证 号 '] ! =$sfzh Or $ SESSION[' 密 码 '] ! = 人 $m) 

{ // 系统 启动 会 话 方式 .首次 登录 或 更 换 密码 ,要 连接 服务 器 检验 ,增加 代码 结束 
Sconn MySQL PConnect ("LocalHost", "ywy",，"ywy211") ; // 连接 服务 器 
If(! $conn) Die ("连接 数据 库 失败 : ".Mysql_Error ()); 

MySQL Select DB('rczp', $conn); // 选择 数据 库 
MySQL Query ("Set Names 'utf8'"); 

// 检验 身份 证 号 及 密码 是 否 正确 

$sql ="Select 姓名 From ypryb Where 身份 证 号 =' $sfzh' and 密码 =' Sm'"; 
Srs -MySQL Query ( $sql, $conn) or Die (mysq] error()); 

If( $result MySQL Fetch Rssoc( $rs)) // 记录 集 非 空 , 则 登录 成 功 

{ $ SESSION[ "身份 证 号 '] =$sfzh; // 注册 会 话 数组 元 素 ,保存 身份 证 号 
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$_SESSION[' 姓 名 '] =Sresult[ "姓名 '] ;// 注册 会 话 数 组 元 素 ,保存 姓名 
S$ SESSION[' 密 码 '] = $mm; // 注册 会 话 数组 元 素 ,保存 密码 
} 
Else Die ( $sfzh.' :登录 失败 !1'); 
} ”// 增加 大 括号 
Echo $ SESSION['" 姓 名 '], "欢迎 您 访问 人 才 招 聘 网 ! <br >'; 
Echo ' 可 以 查看 本 人 < 人 A href "SBKH.PHP" > 申报 考核 </RA 六 息 '; 
} ?></Body ></HTML > 
除了 修改 Login11_6. PHP 中 的 代码 外 ,还 要 将 SBKH. PHP 中 的 代码 “//Session_Start 
() " 改 为 : 


If (StrLen (Session ID ()) ==0) Session Start () 


其 中 ,Session_ID 函数 的 返回 值 为 空 串 (长 度 为 0) 表 示 需 要 用 程序 启动 会 话 方式 , 调 
用 Session_Star 函数 启动 会 话 。 


11.3.4 注销 Session 会 话 及 会 话 元 素 


使 用 Session 技术 将 用 户 会 话 信息 保存 在 Web 服务 器 中 ,可 能 存在 个 人 信息 泄漏 等 
安全 隐患 ,因此 ,通常 要 注销 (删除 ) PHP 程序 中 暂时 不 用 的 会 话 信息 。 在 PHP 程序 中 , 注 
销 会 话 信息 有 注销 会 话 元 素 和 注销 会 话 两 种 方法 。 

1. 注销 会 话 元 素 

在 PHP 程序 中 调用 Unset 函数 可 以 注销 超 全 局 关联 数组 $ _SESSION 中 的 某 个 元 素 。 

函数 格式 : 

Unset($_SESSION[ 元 素 下 标 ]) 

例如 ,在 Login11_7. PHP 中 “| ? > ”之 前 加 语句 Unset( $ _SESSION[' 身份 证 号 ' ] ) ， 
将 注销 $_SESSION[' 身份 证 号 ' ] 元 素 , 从 Web 服务 器 中 删除 身份 证 号 信息 。 在 浏览 器 中 
执行 Login11_7. PHP 时 , 单 击 “ 申 报考 核 " 链 接 将 出 现 “Undefined index: 身份 证 号 "出 错 
信息 。 

清空 $ _SESSION ,可 以 一 次 性 注销 $ _SESSION 中 的 全 部 元 素 ,但 仍然 保留 会 话 标识 
符 及 $_SESSION。 例 如 ,执行 $_SESSION = Array( ) 。 

2. 注销 会 话 

函数 格式 : 

Session Destroy () 

在 PHP 程序 中 调用 Session _Destroy 函数 可 以 注销 会 话 , 包括 会 话 标 识 符 、$ _ 


SESSION 数组 及 其 Web 服务 器 中 对 应 的 文件 。 当 然 , 可 以 调用 Session_Start 函数 ,再 启动 
另 一 个 新 会 话 。 
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【 例 11.8】 在 服务 器 端 人 才 招 聘 网 站 目录 下 新 建 Logout11_8. PHP ,注销 会 话 信息 。 
Logout11_8. PHP 网 页 程序 代码 如 下 : 

<2?PHP 

SetCookie ("PHPSESSID","",Time() 了 4);  // 通知 客户 端 注 销 会 话 标识 符 PHPSESSID 
Session Start () 7 

Session Destroy(); // 服务 器 端 注 销 会 话 ,删除 所 有 会 话 信息 

有 

<HTML ><Head > Meta Charset ="utf -8" ><Title 注销 </Title ></Head > 

<Body ><Center ><a href ="Index11 4.PHP" 注销 成 功 , 单 击 跳 转 到 主 网 页 。 </a > 

</Center > </Body > </HIML > 


使 用 浏览 器 访问 网 页 Index11_4, 单 击 链接 “注销 ” ,在 网 页 Logoutl1_8 中 单 击 链接 
“注销 成 功 , 单 击 跳 转 到 主 网 页 ” ,会 话 信息 已 注销 , 主 网 页 不 再 显示 相关 内 容 。 


习 题 
一 、 填 空 题 


1. 是 指 一 个 终端 用 户 与 系统 进行 通信 的 过 程 。 
2. 服务 器 端 管 理 同 一 用 户 发 出 的 不 同 请 求 之 间 的 关联 , 称 为 ”中 “会话 ,需要 使 





用 如。 

3. HTTP 协议 是 一 种 “的 协议 , 即 HTTP 协议 无 法 维护 同一 个 用 户 的 两 个 事务 之 
间 的 状态 。 

4. 在 网 页 程序 设计 中 ,通常 使 用 QD 技术 和 ”@ 技术 实现 会 话机 制 。 

5. Cookie 技术 将 会 话 信息 封装 到 HTTP 协议 ”发送 到 Web 服务 器 。 

6 Cookie 技术 将 会 话 信息 全 部 保存 在 。 

7. Session 技术 将 会 话 信息 全 部 保存 在 。 

8. 会话 即 是 删除 有 关 会 话 信息 。 

9. 使 用 Cookie 技术 时 ,如 果 启 动 会 话 时 没有 设置 有 效 期 ,会 话 信息 存储 在 客户 端 计 


算 机 中 。 

10. 使 用 Cookie 技术 时 ,在 PHP 程序 中 调用 _QD 函数 可 以 新 增 \ 修 改 或 注销 会 话 
信息 ,会 话 信息 以 _@ ”和 值 的 形式 表示 。 

11. 使 用 Session 技术 时 ,启动 会 话 有 _(D 启动 和 ”@ 启动 两 种 方式 。 

12. Apache 服务 器 的 session. auto_start 选项 值 为 ” ”时 ,系统 自动 启动 会 话 。 

13. 使 用 Session 技术 时 ,在 程序 启动 会 话 方式 下 调用 函数 可 以 启动 会 话 。 

14. 使 用 Session 技术 时 ,在 PHP 程序 中 调用 ”函数 可 以 注销 超 全 局 关联 数组 中 
的 某 个 元 素 。 

15. 使 用 Session 技术 时 ,在 PHP 程序 中 调用 函数 可 以 注销 会 话 标识 符 . 超 全 局 
关联 数组 及 其 对 应 的 会 话 文件 。 
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二 、 单 选 题 
1. 下 列 关 于 Cookie 技术 的 描述 中 ,正确 的 是 ( je 
A. 浏览 器 对 Cookie 文件 的 个 数 无 限制 
B. 浏览 器 对 Cookie 文件 的 大 小 无 限制 
C. 维护 会 话 依赖 于 服务 器 端 对 会 话 信息 的 存储 和 发 送 
D. 会 话 信息 存储 在 客户 端的 内 存 或 磁盘 中 
2. 使 用 Cookie 技术 ,会 话 信息 存储 在 客户 端 硬盘 中 时 ,以 下 情况 不 会 注销 会 话 信息 





J 征 ( )s 
A. 计算 机 关机 B. 会 话 超期 
C. 服务 器 发 送 删除 会 话 命令 D. 会 话 文件 数量 超出 浏览 器 设置 上 限 
3. 使 用 Session 技术 ,服务 器 端 通过 配置 ( ) 文件 设置 会 话 参数 。 
A. HTTPD. CONF B. PHP. INI 
C. MY. INI D. Session. INI 
4. Apache 服务 器 默认 的 PHP 程序 会 话 标 识 符 是 ( )。 
A. PHPID B. SessionID C. PHPSESSID D. ApacheID 
5. Apache 服务 器 的 ( ) 选 项 ,用 于 指定 会 话 标识 符 在 客户 端的 过 期 时 间 。 
A. session. use_cookies B. session. cookie_lifetime 
C. session. gc_maxlifetime D. session. gc_probability 
6. Apache 服务 器 的 ( ) 选 项 ,用 于 指定 会 话 信息 在 服务 器 端的 过 期 时 间 。 
A. session. use_cookies B. session. cookie_lifetime 
C. session. gc_maxlifetime D. session. auto_start 


7. 关于 Session_Start 函数 ,下 列 说 法 正确 的 是 ( ) 
A. 程序 启动 会 话 和 系统 自动 启动 会 话 方式 下 都 可 调用 
B. 程序 启动 会 话 方式 下 每 个 PHP 程序 只 能 调用 一 次 
C. 系统 自动 启动 会 话 方式 下 每 个 PHP 程序 只 能 调用 一 次 
D. 只 能 在 系统 自动 启动 会 话 方式 下 调用 
8. 使 用 Session 技术 ,以 下 方法 能 够 实现 同一 用 户 在 多 个 客户 端 共 享 会 话 信息 的 是 


A. 程序 中 使 用 系统 自动 生成 的 会 话 标识 符 值 

B. 程序 中 指定 教学 号 为 会 话 标识 符 值 

C. 程序 中 指定 姓名 为 会 话 标识 符 值 

D. 程序 中 指定 登录 时 间 为 会 话 标识 符 值 

9. 判断 ( ) 函数 返回 值 可 以 分 析 会 话 是 否 启动 。 
A. Session_ID B. Session_Start 
C. Unset D. Session_Destroy 


10. 使 用 Session 技术 ,服务 器 端的 会 话 文件 内 容 中 不 包含 ( js 
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A. 变量 名 B. 数据 类 型 C. 值 D. 有 效 期 


人 


. 下 列 描述 中 ,不 属于 Cookie 技术 缺陷 的 是 ( 屿 
. 会 话 信息 存储 量 小 
. 会 话 信息 不 安全 
. 会 话 信 息 不 能 跨 平台 共享 
. 增加 了 服务 器 端 存储 设备 的 压力 
.依赖 于 Session 技术 
2. 下 列 关 于 Session 技术 的 描述 中 ,错误 的 是 ( ) 。 
A. 会 话 信息 存储 量 大 B. 服务 器 端 保存 全 部 会 话 信息 
C. 客户 端 不 保存 任何 会 话 信息 D. 依赖 于 Cookie 技术 
E. 会 话 信 息 安全 主要 依赖 于 客户 端 计算 机 
3. 下 列 关于 会 话 信 息 的 描述 中 ,错误 的 是 ( 5 
A. 使 用 Cookie 技术 ,设置 会 话 信息 有 效 时 间 可 以 通过 调用 相关 函数 
B. 使 用 Cookie 技术 ,所 有 会 话 信息 的 有 效 时 间 必 须 相 同 
C. 使 用 Cookie 技术 ,会 话 信息 有 效 时 间 不 能 修改 
D. 使 用 Session 技术 ,会 话 信息 的 有 效 时 间 存 储 在 会 话 文件 中 
E. 使 用 Session 技术 ,设置 会 话 信息 有 效 时 间 可 以 通过 修改 配置 文件 
4. 在 PHP 程序 中 引用 超 全 局 关联 数组 ( ) 中 元 素 可 以 获取 会 话 信息 。 


日 已 路 双关 








on B. $_COOKIE C. $_SESSION 
D. $_POST E. $_ENV 

5. 使 用 Cookie 技术 ,以 下 操作 一 定 会 注销 会 话 信息 的 是 ( 说 
A. 调用 SetCookie 函数 B. 关闭 浏览 器 
C. 删除 全 部 Cookie 文件 D. 关闭 计算 机 


E. 使 用 浏览 器 "删除 Cookie 和 网 站 数据 "功能 
6. Apache 服务 器 的 ( ) 选 项 ,用 于 指定 服务 器 端 启动 垃圾 回收 进程 的 概率 。 


A. session. use_cookies B. session. cookie_lifetime 
C. session. gc_maxlifetime D. session. gc_probability 
E. session. gc_divisor 

Fe ) 函数 配合 ,可 以 在 创建 会 话 时 自 定义 会 话 标识 符 的 值 。 
A. Unset B. Session_ID 
C. Session_Start D. Session_Destroy 
E. Session_Encode 


8. 下 列 关于 会 话 信息 的 描述 中 ,正确 的 是 (。””)。 
A. 使 用 Cookie 技术 ,可 以 在 程序 中 自 定义 变量 作为 会 话 标识 符 
B. 使 用 Cookie 技术 ,会 话 标识 符 值 可 以 在 程序 中 自 定义 
C. 使 用 Session 技术 ,会 话 标识 符 可 以 在 程序 中 自 定义 
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D. 使 用 Session 技术 ,会话 标识 符 不 可 以 自 定义 
E. 使 用 Session 技术 ,会 话 标识 符 值 可 以 在 程序 中 自 定义 
9. 下 列 关于 存储 会 话 信息 的 超 全 局 关联 数组 描述 中 ,正确 的 是 ( )。 
A. 使 用 Cookie 技术 和 Session 技术 ,在 程序 中 引用 的 超 全 局 关联 数组 名 相同 
B. 使 用 Cookie 技术 和 Session 技术 ,在 程序 中 引用 的 超 全 局 关联 数组 名 不 同 
C. 使 用 Cookie 技术 , 超 全 局 关联 数组 元 素 只 能 在 客户 端 引 用 
D. 使 用 Session 技术 , 超 全 局 关联 数组 元 素 只 能 在 服务 器 端 引 用 
E. 使 用 Cookie 技术 和 Session 技术 , 超 全 局 关联 数组 元 素 在 客户 端 和 服务 器 端 都 
可 以 引用 
10. 下 列 关 于 会 话 信息 的 描述 中 ,正确 的 是 ( ) 。 
A. 使 用 Cookie 技术 ,服务 器 端 不 保存 会 话 信息 
B. 使 用 Cookie 技术 ,客户 端 和 服务 器 端 都 保存 会 话 信息 
C. 使 用 Session 技术 ,服务 器 端 不 保存 会 话 信息 
D. 使 用 Session 技术 ,客户 端 保存 会 话 信息 
E. 使 用 Session 技术 ,客户 端 和 服务 器 端 都 保存 会 话 信息 


、 程序 设计 题 
1. 使 用 会 话 技术 ,结合 人 才 招 聘 数 据 库 中 的 ypryb 表 编 写 网 页 程序 ,在 人 才 招 聘 网 页 


中 显示 应 聘 人 员 出 生日 期 和 性 别 。 
2. 修改 例 11.2 中 的 程序 代码 ,在 客户 端 以 密 文 形式 保存 密码 。 





1. 如 果 客 户 端 浏览 器 禁用 了 Cookie ,访问 网 站 时 如 何 实现 会 话机 制 ? 
2. 使 用 Cookie 技术 时 ,如 何 实现 多 客户 端 共享 会 话 信息 ? 

3. 使 用 Cookie 技术 时 ,如何 提 高 会 话 信息 的 安全 性 ? 

4. 不 同 的 网 络 应 用 系统 之 间 如 何 共享 会 话 信息 ? 
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移动 互联 网 网 页 及 程序 设计 


随 着 互联 网 技术 的 高 速 发 展 ,互联 网 被 划分 为 计算 机 互联 网 和 移动 互联 网 。 通 常 将 
以 台式 或 笔记 本 计算 机 作为 访问 终端 的 互联 网 称 为 计算 机 互联 网 ;将 手机 或 平板 电脑 等 
移动 设备 作为 访问 终端 的 互联 网 称 为 移动 互联 网 。 

计算 机 互联 网 访问 的 站 点 称 为 Web 站 点 ,使 用 移动 设备 访问 普通 Web 站 点 会 出 现 
无 法 打开 或 网 页 格式 错乱 等 现象 ,原因 是 移动 互联 网 访问 专属 的 WAP ( Wireless 
Application Protocol ,无 线 应 用 协议 ) 站 点 或 用 HTMLS 开发 的 Web 站 点 。 伴 随 移动 互联 网 
的 崛起 和 智能 手机 的 普及 ,两 种 互联 网 的 边界 越 来 越 模糊 ,手机 从 简单 的 通信 设备 发 展 成 
为 互联 网 的 主要 接 入 设备 , 越 来 越 多 的 人 使 用 手机 浏览 网 页 ,发送 邮件 或 运行 网 络 应 用 
程序 。 

由 于 手机 和 计算 机 在 硬件 软件 网络 接 入 方式 和 使 用 习惯 等 方面 存在 差异 ,使 得 手 
机 网 页 程序 设计 有 其 特殊 性 。 如 何 忽 略 访问 终端 的 差异 性 ,使 网 页 能 够 被 各 种 手机 正常 
访问 ,已 成 为 移动 互联 网 网 页 程序 设计 的 重要 内 容 。 实 际 开 发 过 程 中 主要 解决 如 下 问题 : 

(1) 手机 与 计算 机 在 硬件 及 浏览 器 方面 存在 哪些 差异 ? 

(2) 移动 互联 网 网 页 设计 有 哪些 标准 ? 

(3) 移动 与 计算 机 的 网 页 设计 有 哪些 差异 ? 

(4) 如 何 搭建 移动 互联 网 网 站 开发 环境 ? 

(5) 如 何 设计 移动 互联 网 网 站 及 其 网 页 程序 ? 

(6) 如 何 调试 移动 互联 网 网 站 及 其 网 页 程序 ? 








12.1 移动 互联 网 终端 和 网 站 


移动 互联 网 终端 包含 手机 和 平板 电脑 等 设备 ,其 中 手机 使 用 最 为 广泛 。 由 于 移动 互 
联网 终端 和 计算 机 在 硬件 软件 .网络 接 入 方式 和 使 用 习惯 等 方面 存在 巨大 差异 ,移动 互 
联网 网 页 程序 设计 与 计算 机 网 页 程序 设计 在 技术 上 也 有 所 不 同 。 设 计 移动 互联 网 网 页 
前 ,需要 了 解 互联 网 终端 与 计算 机 硬件 .浏览 器 差异 和 网 页 设计 标准 等 问题 。 


12.1.1 终端 系统 


1. 硬件 系统 


手机 与 计算 机 在 硬件 配置 上 的 差异 将 影响 移动 互联 网 网 页 程序 设计 , 主要 差异 
如 下 。 

(1) 中 央 处 理 器 : 手机 采用 和 能 入 式 CPU ,与 基于 x86 架构 的 计算 机 CPU 相 比 性 能 有 
明显 不 足 。 因 此 ,手机 浏览 器 打开 网 页 的 速度 慢 ,时 常会 出 现 卡 顿 现象 。 设 计 手机 网 页 
时 ,要 避免 使 用 过 多 的 网 页 元 素 。 

(2) 显示 设备 : 计算 机 显示 器 尺寸 通常 在 14in( 英 寸 ) 以 上 ,手机 显示 屏 尺 寸 为 3.5 
~6in, 可 以 用 于 显示 网 页 的 面积 小 。 手 机 显示 屏 尺 寸 虽 然 小 ,但 是 分 辩 率 并 不 低 , 目前 中 
高 端 手机 分 辩 率 可 达到 1920 x 1080px, 达 到 了 多 数 计算 机 显示 器 的 分 辩 率 。 此 外 ,手机 
触摸 屏 有 两 种 显示 模式 ,可 以 横 屏 或 竖 屏 显示 。 

使 用 手机 浏览 计算 机 网 页 ,由 于 显示 屏 像 素 密度 高 ,图 片 或 文字 实际 显示 效果 偏 小 。 
图 12-1 为 手机 浏览 计算 机 网 页 和 移动 互联 网 网 页 的 效果 ,很 明显 后 者 浏览 效果 更 好 。 
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(a) 计算 机 网 页 (b) 移动 互联 网 网 页 
图 12-1 手机 浏览 计算 机 网 页 和 移动 互联 网 网 页 效果 对 照 


(3) 输入 设备 : 手机 通过 手指 定位 输入 ,精度 低 ; 计 算 机 使 用 鼠标 或 键盘 输入 ,定位 
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精度 高 。 
(4) 其 他 硬件 设备 : 手机 拥有 光线 传感器 .距离 传感器 .重力 传感器 .GPS 陀螺 仪 和 
指纹 传感器 等 多 种 传感器 ,在 网 页 中 可 以 使 用 某 些 传感器 的 功能 ,如 GPS 地 理 定位 。 


2. 浏览 器 


手机 浏览 器 主要 有 Safari .Chrome .UC .QQ .百度 和 搜狗 等 。 多 数 浏览 器 都 是 基于 
Webkit 内 核 开发 的 ,对 网 页 的 解析 表现 一 致 ,版 本 更 新 速度 快 ,支持 新 技术 和 新 标准 , 主 
流 智能 手机 浏览 器 都 支持 HTML5 和 CSS3 ,网 页 兼容 性 较 好 。 计 算 机 的 还 、Firefox 和 
Chrome 等 浏览 器 使 用 不 同 内 核 , 网 页 解析 有 时 出 现 不 一 致 现象 ,兼容 性 并 不 理想 。 


12.1.2 网 页 设计 标准 


手机 能 够 访问 基于 无 线 应 用 协议 (WAP) 标 准 设计 的 WAP 网 站 ,或 是 基于 HTMLS 标 
准 设计 的 移动 互联 网 网 站 。WAP 网 站 是 专门 为 手机 等 移动 设备 开发 的 ,对 高 中 低 端 各 类 
手机 兼容 性 好 ;移动 互联 网 网 站 使 用 HTMLS 标准 设计 ,能 够 同时 被 计算 机 和 手机 浏览 器 
正常 访问 ,打破 了 传统 计算 机 网 站 和 移动 互联 网 网 站 的 界限 。 

1. WAP2.0 标准 

WAP2.0 标准 使 用 XHTML MP(XHTML Mobile Profile ,XHTML 移动 纲要 ) 标 记 语言 ,是 
HTMIL4.0 标准 的 子 集 。XHTML MP 与 HTML4.0 文档 比较 ,有 如 下 一 些 特点 。 

(1) 艇 套 标签 时 ,要 求 严格 按 内 外 层 关系 编写 。 例 如 ,HTML4.0 的 如 下 代码 : 

人 > 中 沁 学 专业 : 计算 机 科学 与 技术 </p ></b> 

改 为 XHTML MP 代码 时 , </b > 和 </p > 位 置 不 能 颠倒 ,必须 写 为 : 

人 > 中 新 学 专业 : 计算 机 科学 与 技术 </b ></p > 

(2) 元 素 必 须 有 结束 标签 。 例 如 , 单 标签 < br > 必须 写成 <br/ > 。 

(3) 标签 名 和 属性 名 必须 是 小 写字 母 ,属性 值 要 用 双 引 号 引起 来 。 

(4) 属性 名 不 能 省 略 。 例 如 ,HTML4.0 的 如 下 代码 : 

<input type ="radio" name ="sex" value 2"]1" checked /> 

在 XHTML MP 中 ,checked 属性 不 能 省 略 ,必须 写 为 : 

<input type ="radio" name ="sex" value 2"1" checked ="checked" /> 

(5) 不 支持 框架 集 ,框架 和 表格 等 标签 。 

使 用 WAP 标准 开发 的 网 页 如 图 12-2 所 示 , 与 目前 主流 的 移动 互联 网 网 页 相 比 较 , 网 
页 布局 简单 ,主题 不 突出 ,缺少 动画 和 交互 效果 。 使 用 文字 链接 进行 页 面 跳 转 ,不 方便 
浏览 。 
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2. HTMLS 标准 





HTMILS 标准 与 HTML4 标准 相 比较 ,增加 了 对 多 媒体 元 素 的 支持 ,可 以 同时 供 移动 终 
端 和 计算 机 浏览 器 访问 ,图 12-3 是 用 HTML5 开发 的 网 站 ,也 称 Web APP。 





分 享 .转载 到 禽 QQ 空间 
相关 新 闻 : 
* 韩 引 美 舰 入 黄海 激 钨 中 国 网 友 

















"日 媒 称 中 国 自信 控制 80% 南 海 

* 澳 猜 想 2018 中 美南 海 空战 图 ) 

* 中 国 南 海战 争 可 能 性 大 增 图 ) 
相关 搜索 : 南海 .海军 ， 军 演 
的 评论 : 


























| 游客 留言 ”登录 

热点 新 闻 

* 考 古 队 否认 曹操 头骨 被 辟 两 半 
* 山 西平 通 每 年 公款 招待 10 万 人 
“温州 一 镇 政府 批 市 政府 引 热 议 
“朝鲜 称 天 安 号 事件 让 美国 受益 
查看 更 多 >> 











图 12-2 WAP 手机 网 页 
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今日 要 闻 1 
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图 12-3 ”HTMLS 手机 网 页 


为 了 兼容 移动 设备 , HTMLS 标准 做 了 巨大 革新 ,与 移动 互联 网 网 页 设计 相关 的 


HTMLS 标签 变化 如 表 12-1 所 示 。 


表 12-1 HTMLS 标签 变化 表 


HTMILS 





不 支持 < frame > 、< noframes > 和 < frameset > 


标签 





不 支持 < basefont > 、< big > 、< center > 、 
<font> .<s> 、<strike > tt> 和 <u> 标 签 


样式 统一 在 CSS 中 设置 





新 增 < article > 、< aside > 、< nav > 、< section 
> 、<header > 、<footer > 和 <hgroup > 标签 


结构 标签 ,使 浏览 器 和 搜索 引擎 能 正常 解析 网 页 内 
容 , 结 构 更 清晰 





新 增 < video > 标签 


视频 标签 ,在 网 页 中 播放 视频 不 再 使 用 第 三 方 插件 





新 增 < audio > 标签 


音频 标签 ,在 网 页 中 播放 音频 不 再 使 用 第 三 方 插件 





图 形容 器 ,结合 脚本 语言 在 网 页 中 绘制 2D 或 3D 图 











人 形 ,增强 了 对 动画 .游戏 的 支持 
新 增 <ombed > 标签 定义 外 部 的 可 交互 内 容 或 插件 ,规范 网 页 插件 
修改 <input > 标签 增加 移动 端的 交互 性 
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12.2 网 页 设计 基础 


由 于 移动 互联 网 终端 与 计算 机 之 间 的 差异 ,直接 将 计算 机 网 页 设计 技术 应 用 到 移动 
互联 网 网 页 设计 中 会 出 现 种 种 问题 。 


12.2.1 像素 和 分 辨 率 


不 同 手机 的 显示 屏 差 异 很 大 ,为 了 使 网 页 在 不 同 手机 上 都 能 够 正常 显示 ,在 设计 手机 
网 页 前 ,首先 需要 和 弄 清 像 屏幕 尺寸 .像素 物理 像素 .像素 密度 逻辑 像素 和 设备 像素 比 等 
手机 网 页 设计 的 基本 概念 。 

(1) 屏幕 尺寸 : 是 手机 显示 屏 对 角 线 长 度 , 单 位 in( 英 寸 )。 目 前 多 数 手机 的 屏幕 尺 
才 为 4~6in, 宽 高 比 通常 为 16: 9。 

(2) 物理 像素 : 又 称 为 设备 像素 ,是 显示 设备 上 的 最 小 显示 单位 ,用 px 表示 。 相 同 
的 设备 ,每 个 物理 像素 的 大 小 相同 。 例 如 ,华为 荣 汐 7 手机 的 屏幕 尺寸 为 5. 2 英寸 ,分 辨 
率 为 1920 x 1080px;iPhone 6 手机 的 屏幕 尺寸 为 5 英寸 ,分 辨 率 为 1920 x 1080px。 

(3) 物理 分 辨 率 : 是 物理 像素 表示 的 分 辨 率 ,又 称 为 设备 分 辨 率 ,通常 所 说 的 手机 分 
辩 率 都 是 指 物理 分 辨 率 。 

(4) 像素 密度 : 是 每 英寸 长 度 上 排列 的 像素 数量 ,用 PPI 表示 ,计算 公式 如 下 : 

PPI = 人 错 向 像素 + 纵 同 像素 ?/ 屏幕 尺寸 

像素 密度 越 高 ,显示 图 像 时 颗粒 感 越 不 明显 。 当 设备 距离 人 眼 25 ~ 30 厘米 ,像素 密 
度 超过 300PPI 时 ,人 眼 几 乎 分 辨 不 出 像素 点 ,通常 将 此 种 屏幕 称 为 视网膜 屏 。 目 前 主流 
手机 的 像素 密度 在 400PPI 左右 。 

只 考虑 物理 分 辩 率 的 情况 下 ,同一 幅 图 在 不 同 像素 密度 的 手机 上 显示 效果 是 不 同 的 ， 
如 图 124 所 示 。 显 示 屏 像素 密度 越 高 ,图 像 显示 越 小 。 


em 





3.5 英 寸 ”480px 3.5 英 十 960px 5 8 闫 二 2280px 
320px 640px 1224px 


图 124 不 同 像素 密度 手机 显示 图 片 效果 
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(5) 逻辑 像素 : 是 编程 所 能 控制 的 最 小 显示 单位 。 计 算 机 显示 器 的 像素 密度 较 低 ， 
人 了 眼 能 够 识别 单个 物理 像素 点 ,物理 像素 和 逻辑 像素 一 致 。 手 机 显示 屏 的 像素 密度 较 高 ， 
人 有 眼 不 能 够 识别 单个 物理 像素 点 ,因此 ,编程 控制 物理 像素 没有 实际 意义 。 手 机 上 物理 像 
素 和 逻辑 像素 不 一 致 。 不 同 手机 物理 像素 和 逮 辑 像素 比 可 能 不 同 , 在 设计 手机 网 页 时 需 
要 考虑 兼容 性 问题 。 

(6) 逻辑 分 辩 率 . 是 逻辑 像素 表示 的 分 辩 率 。 计 算 机 逻辑 分 辨 率 可 以 由 用 户 自 定 
义 ,手机 通常 不 允许 。 

(7) 设备 像素 比 : 物理 像素 与 逻辑 像素 的 比值 ,用 DPR 表示 。 设 置 合理 的 设备 像素 
比 , 可 以 使 同一 幅 图 在 不 同 手机 上 显示 大 小 差不多 。 

不 同型 号 的 手机 在 屏幕 尺寸 .像素 物理 像素 .像素 密度 . 旭 辑 像素 和 设备 像素 比 等 参 
数 上 存在 较 大 差异 ,如 表 12-2 所 示 。 


表 12-2 iPhone 手机 显示 屏 参 数 表 






































iPhone 设备 对 角 线 /in 逻辑 分 辨 率 /px | 物理 分 辩 率 /px 设备 像素 比 像素 密度 /ppi 
3GS 3.5 320 x 480 320 x 480 1 163 
4(S) | 320 x480 640 x960 入 326 
5C 4 320 x568 640 x 1136 2 326 
M3) 4 320 x568 640 x 1136 | 326 
6 4.7 375 x667 750 x 1334 2 326 
6plus 全 414 x736 1242 x2208 3 401 
12.2.2 视 口 


视 口 是 显示 设备 上 具有 特定 显示 功能 的 矩形 区 域 。 例 如 ,浏览 网 页 时 浏览 器 窗口 就 
是 视 口 。 计 算 机 网 页 的 宽度 通常 定义 为 980px 或 1024px ,小 于 目前 主流 计算 机 显示 器 的 
分 辨 率 宽 度 ,浏览 器 提供 的 视 口 足够 显示 网 页 。 直 握手 机 时 ,手机 逻辑 分 辩 率 的 宽度 通常 
为 320px 左右 , 远 小 于 普通 计算 机 网 页 宽度 ,需要 用 布局 视 口 视觉 视 口 和 理想 视 口 解决 
网 页 的 显示 问题 。 

(1) 布局 视 口 : 宽度 由 操作 系统 指定 的 虚拟 视 口 ,用 逻辑 像素 表示 。 为 了 正常 显示 
计算 机 网 页 ,布局 视 口 宽度 远大 于 屏幕 宽度 ,通常 默认 为 980px。 打 开 网 页 时 ,i0S 和 安 卓 
操作 系统 先 在 布局 视 口中 排版 ,然后 在 浏览 器 窗口 中 缩小 显示 。 使 用 默认 布局 视 口 ,不 需 
要 修改 计算 机 网 页 代码 ,实际 是 将 网 页 先 排版 再 缩小 显示 ,虽然 样式 不 会 错乱 ,但 是 网 页 
中 元 素 看 上 去 很 小 。 

(2) 视觉 视 口 : 屏幕 上 的 可 视 区 域 ,用 物理 像素 表示 。 手 机 浏览 器 窗口 大 小 不 允许 
缩放 ,视觉 视 口 与 手机 物理 分 辨 率 宽 度 相等 。 由 于 手机 通常 直 握 使 用 ,目前 多 数 手机 视觉 
视 口 宽度 小 于 默认 布局 视 口 。 

(3) 理想 视 口 : 宽度 与 屏幕 逻辑 分 辩 率 相等 的 视 口 ,不同 手机 的 理想 视 口 宽度 可 能 
不 同 。 
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设计 手机 网 页 时 ,通过 网 页 文档 声明 和 设置 CSS 属性 协调 三 个 视 口 的 关系 ,使 布局 
视 口 和 理想 视 口 宽度 一 致 ,网 页 不 需要 缩放 就 能 够 正确 显示 。 


12.3 网 页 布局 与 样式 设计 


移动 互联 网 网 页 布局 比较 固定 ,如 图 12-5 所 示 。 以 手机 为 例 ,通常 采用 页 头 、 主 体 和 
页 脚 三 段 式 布局 。 在 布局 时 ,为 了 使 浏览 器 能 够 更 好 地 解析 网 页 结构 ,需要 用 结构 标签 。 





<body> 


article 


<header> 


<section> 


<footer> 


图 12-5 移动 互联 网 网 页 布局 



































1. 结构 标签 


在 HTMLS 规范 中 新 增 的 结构 标签 ,可 以 使 整个 HTML 文档 结构 语义 更 加 清晰 ,网 页 
内 容 更 容易 被 搜索 引擎 解析 ,各 种 不 同 设备 都 能 够 兼容 显示 网 页 。 结 构 标 签 包 括 
<header > 、< hgroup > 、< nav > 、< footer > 、< article > 、< aside > 和 < section > 等 ,如 
表 12-3 所 示 。 
表 12-3 ”Htmls 结构 标签 表 
标签 说 明 


定义 网 页 或 区 段 (内 容 块 ) 的 页 眉 ,在 页 眉 中 可 以 显示 标题 .LOGO 或 
导航 栏 等 ,一 个 网 页 中 可 以 使 用 多 个 < header > … < /header > 标签 


<hgroup > … </hgroup > 网 页 或 区 段 (section) 有 多 级 标题 时 ,使 用 该 标签 对 标题 进行 分 组 
<nav>* </nav> 定义 网 页 的 导航 链接 区 域 


定义 网 页 或 区 段 的 页 脚 ,用 于 描述 作者 版权 发 布 日 期 或 备案 号 等 信 
息 ,一 个 网 页 中 可 以 使 用 多 个 <footer > … < /footer > 标签 





<header > … </header > 











<footer > … </footer > 
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( 续 表 ) 
标签 说 明 





定义 网 页 中 文章 .评论 或 论坛 帖子 等 相对 独立 的 内 容 , 可 以 嵌 套 使 用 ， 
对 内 容 进行 整合 


<article > … </article > 





定义 文章 的 附属 信息 ,例如 与 当前 文章 有 关 的 同类 文章 或 名 词 解 释 
等 ,也 可 以 定义 网 页 的 侧 栏 


<aside > … </aside > 





定义 文档 中 的 段落 或 节 , 段 落 表 示 一 篇 文章 中 按照 主题 的 分 段 , 节 表示 
< section > .… < /section > 一 个 页 面 中 的 分 组 ,通常 与 <article > 标签 嵌 套 使 用 ,表示 < article > 标 
签 中 相对 独立 的 内 容 





【 例 12.1】 用 结构 标签 设计 通用 的 移动 互联 网 网 页 模板 ,显示 效果 如 图 12-6 所 示 。 


26B/s 加 东 过 87% 画 ) 04:25 





侠 移动 互联 网 网 页 模板 C 





段落 1 
段落 2 











图 12-6 移动 互联 网 网 页 模板 实例 


<!DOCTYPE html > <html > <head > <meta charset ="UTF -8" > 
‘<meta name ="viewport" content ="width =device -width, user -scalable no, 
initial -scale 3 .0, mximm -scale3.0, minimm-scale3.0"> 

<title 渴 动 互联 网 网 页 模板 </title > 

<style type ="text/css" > 
body {margin:0} 
header {width:100% ;height :50px;background: 扣 266cc; color: #ff; } 
nav{width:100% ;height :30px;background:#Ef66cc; color: #¥ff; } 
aside{width:30% ;height :340px; float :left;background:$3ffcc; } 
article{width:70% ;background:#Efffcc;float:left;text -align:center;} 
section{width: 100% ; background: #2f2f2; float: left; overflow: auto; text — align: 
center; } 
footer {width:100% ;height :50px;background:green; clear:both; color: #¥ff;} 

</style ></head > 

<body ><header > <hgroup > <h3 淋 题 </h3 ></hgroup ></header > 
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<nav > 导航 栏 </nav ><aside > 侧 边 栏 </aside > 
<article > 文章 <section 怀 落 1 </section ><section 怀 落 2 </section ></article > 
<footer 3 页 脚 </footer ></body ></html > 


移动 互联 网 网 页 布局 时 需要 注意 结构 标签 之 间 的 嵌 套 。 
2. 其 他 元 素 标签 


(1) <time >…</time > 标签 : 定义 日 期 或 时 间 。 

。 datetime 属性 : 定义 日 期 /时 间 ,如 果 省 略 , 则 由 元 素 的 内 容 定义 。 
。 pubdate 属性 : 定义 文档 或 最 近 的 < article > 元素 的 发 布 日 期 。 
【 例 12.2】 使 用 <time > 标签 描述 文章 发 布 日 期 。 


<article > header > 

<hl > 人 才 招 聘 网 站 将 于 <time datetime ="2017 -01 -01" 22017 年 1 月 1 日 </time > 正式 上 线 </ 
hl > 

< 中 发布 time datetime ="2016 -2 -15" pubdate 况 016 年 12 月 15 日 </time></p> 

</header > 

< 介 > 人 才 招 聘 网 站 是 一 个 发 布 最 新 招聘 信息 的 网 站 。 </p ></article > 


(2) <figure >… </figure > 标签 : 定义 独立 的 图 文 内 容 。 

(3) < figcaption > … </figcaption > 标签 : 定义 figure 元 素 的 标题 , 必须 舱 套 在 
<figure > 元素 内 ,最 多 只 允许 舱 套 一 个 figcaption 元 素 。 

【 例 12.3】 使 用 <figure > 标签 设置 网 站 LOGO。 

<figure > 

<img src ="l0g.jpg" alt 玫 " 图 标 " / ><figcaption > 人 才 招 聘 网 站 </figcaption > 
</figure > 
(4) <input > 标签 : 为 手机 显示 屏 输入 提供 更 好 的 输入 控制 和 验证 ,如 表 124 所 示 。 
表 124 ”<input > 标签 type 属性 表 

type 属性 值 说 明 示例 代码 


包含 E-mail 地 址 的 输入 域 。 在 提 
交 表 单 时 ,浏览 器 按 email 语法 格 
式 自动 验证 输入 域 的 值 。 如 果 格 式 
email 不 正确 , 则 无 法 提交 表单 。 当 输入 | <input type ="email" name = "zpgs_email" /> 





自动 改变 触摸 屏 键 盘 样 式 ,添加 @ 
和 . com 虚拟 按键 

包含 URL 地 址 的 输入 域 。 在 提交 
表单 时 ,浏览 器 按 url 语法 格式 自 
动 验证 输入 域 的 值 。 如 果 格 式 不 正 
url 确 , 则 无 法 提交 表单 。 当 输入 焦点 | <input type = "ud" name ="zpgs_url" /> 
在 ud 类 型 输入 域 时 ,系统 自动 改 
变 触 摸 屏 键盘 样式 ,添加 . com 虚拟 
按键 
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type 属性 值 


说 明 


( 续 表 ) 
示例 代码 





包含 数值 的 输入 域 ,可 以 设 定数 值 


< input type = " number" name =" ypry_age" min 


























be 

ee 的 上 限 和 下 限 ="18" max="60" /> 

包含 一 定 范围 内 数值 的 输入 域 , 显 | <input type = "range" name =" ypry_pay" min=" 
range 示 为 滑动 条 ,可 以 设 定 滑动 条 的 上 | 2500" max =" 6000" step =" 100" value = 

限 、 下限. 步 长 和 默认 值 "3000"/ > 
date 年 月 .日 选择 器 <input type ="date" name ="publish_date" / > 
month 年 月 选择 器 <input type ="month" name ="publish_date" / > 
week 年 、 周 选择 器 <input type = " week" name ="publish_date" /> 
time 时 间 ( 小 时 和 分 钟 ) 选 择 器 <input type = "time" name = "publish_date" / > 
datetime | 年 .月 .日 \ 时 间 (UTC 时 间 ) 选 择 器 | < "Pt type =" datetime 

name =" publish_date" / > 
datetime- < input type =" datetime-local " 
3 村 D 先 

jal 年 .月 \ 日 \ 时 间 ( 本 地 时 间 ) 选 择 器 |。 pallidh dolen /S 





【 例 12.4】 网 页 表单 中 用 年 月 选择 器 填写 出 生 信息 ,效果 如 图 12-7 所 示 。 








:| 现时 年 0 月 x> 








2017 年 0 月 

















图 12-7 使 用 年 月 选择 器 的 移动 互联 网 网 页 表单 


<!DOCTYPE HIML ><html ><boqdy > 
<form action ="# method ="get" > 


出 生年 月 : <input type ="'mont 


" name ="user date" /> 


<input type ="submit" / ></form></body ></html > 
使 用 年 月 选择 器 便于 在 移动 设备 浏览 器 中 输入 日 期 数据 。 


3. 网 页 样式 


在 设计 网 页 时 ,使 用 圆 角 边框 . 块 阴 影 和 文字 阴影 可 以 使 网 页 显示 更 有 立体 感 。 

(1) 圆 角 边 框 : 在 CSS3 中 ,使 用 border-top-left-radius \ border-top-right-radius \ border- 
bottom-right-radius 和 border-bottom-left-radius 四 个 属性 可 以 分 别 设置 左上 、 右 上 、 右 下 和 
左下 角形 状 , 也 可 以 使 用 border-radius 属性 同时 设置 四 个 角形 状 ,属性 说 明 如 表 12-5 


所 示 。 
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表 12-5 角形 状 属性 表 














属性 名 中 文 合 义 属性 值 使 用 说 明 
border-top-left-radius 左上 角形 状 pe [过 让 不 多 证 负 和， pe 
时 ,与 水 平 半径 值 相同 
border-top-right-radius 右上 角形 状 同上 
border-bottom-right-radius 右 下 角形 状 同上 
border-bottom-left-radius 左下 角形 状 同上 





border-radius 





四 个 角形 状 


例如 ,border-radius:3 px 等 价 于 


border -top -left -radius:3 px; 





左上 角 水 平 半径 
[右上 角 水 平 径 ] 
[ 右 下 角 水 平 半 
径 ] [左下 角 水 平 
半径 ][/][ 左 上 角 
垂直 半径 ] [右上 
角 垂 直径 ] [ 右 下 
角 垂 直 半 径 ] [ 左 
下 角 垂 直 半径 ] 





水 平 半 径 设置 1 个 值 时 ,4 个 角 值 
相同 ;设置 2 个 值 时 ,左上 和 右 下 角 
使 用 第 一 个 值 ,右上 和 左下 角 使 用 
第 二 个 值 ;设置 3 个 值 时 ,左上 角 使 
用 第 一 个 值 ,右上 和 左下 角 使 用 第 
二 个 值 , 右 下 角 使 用 第 三 个 值 。 不 
设置 垂直 半径 值 时 , 与 水 平 半径 值 
相同 ;设置 垂直 半径 值 时 ,规则 与 水 
平 半径 值 相同 


border -op -right -radius:3 px; 


border -bottom -right -radius:3 px; border bottom -left -radius:3 px; 
border -radius:12px 10px 4px / 5px 3px 等 价 于 
border -top -left -radius: 12px 5px; border -top -right -radius: 10px 3px; 

border -bottom -right -radius: 4px 5px; border -bottom -left -radius: 10px 3pxo 


(2) 元 素 块 阴影 . 在 CSS3 中 设置 box-shadow 属性 可 以 实现 元 素 块 阴影 效果 ,box- 


shadow 属性 有 6 个 值 ,如 表 12-6 所 示 。 


表 12-6 ”box-shadow 属性 表 




















属性 值 中 文 含义 使 用 说 明 
h-shadow 水 平 阴 影 位 置 必需 , 正 值 时 阴影 在 对 象 的 右边 , 负 值 时 阴影 在 对 象 的 左边 
v-shadow 垂直 阴影 的 位 置 | 必需 , 正 值 时 阴影 在 对 象 的 底部 , 负 值 时 阴影 在 对 象 的 顶部 
blur 模糊 距离 可 选 
spread 阴影 的 尺寸 可 选 
color 阴影 的 颜色 可 选 
inset 内 部 阴影 可 选 ,默认 为 外 部 阴影 








(3) 文本 阴影 效果 : 在 CSS3 中 设置 text-shadow 属性 可 以 实现 文本 阴影 效果 ,text- 


shadow 属性 有 h-shadow 、v-shadow blur 和 color 四 个 值 , 属性 值 含 义 与 box-shadow 


相同 。 


【 例 12.5】 





属性 


设计 具有 圆 角 和 阴影 效果 的 移动 互联 网 网 页 ,显示 效果 如 图 12-8 
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所 示 。 

















回 本 104B/s t 全 国 68% 国 0 11:30 
* 公司 名 称 : 工行 前 进 支行 
。 岗位 名 称 : 会 计 
。 聘任 要 求 : 笔试 经 济 学 + 金融 
。 人数: 3 
\ 
< = 个 品 





图 12-8 具有 圆 角 和 阴影 效果 的 移动 互联 网 网 页 


<!DOCTYPE html > html > <head > meta charset ="UTF -8" > 
‘<meta name ="viewport" content ="width =device -width, user -scalable no, 
initial -scale3.0, mximm-scale34.0, minimm -scale3.0"> 

<title 3 竹 机 网 页 圆 角 和 阴影 实例 </title > 
<style type ="text/css" > 

body {margin:0} 

header {width:100% ;height :60px;background: 扎 266cc; color: #ff;} 

h3 {text -shadow:2px 2px 8px #*CCC00;} 

h2 {display:inline;text -shadow:2px 2px 8px 抽 BOFFFF'; } 

. Section {width: 100% ; background: #2f2f2; float: left; overflow: auto; text -align: 

center;} 

.divcontent {padding: 10px; text -align: left; width: 90% ; height: 100px; background: 

#ee220; 

border:1px solid $da8cb;margin:0 auto 15px auto; 
border -radius:15px; box -shadow:0 0 10px 担 0CCCC; } 

</style ></head > 
<body > header > 
<hgroup > <img alt = 一" height "50px" src "images/ 人 才 招 聘 logo.gif" ><h2 > 人 才 招 聘 </h2 
</hgroup > </header > 
<section class ="section" > 

<43 北新 岗位 wh3 ><div class ="divcontent" ><ul ><Li > 公司 名 称 : 工行 前 进 支行 1i > 

<i 疯 位 名 称 : 会 计 <1i ><i : 珊 任 要 求 : 笔试 经 济 学 + 金融 </1i> 
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<Li > 人 数 : 3 </1i></ul ></div ></section ></body ></html > 


设计 时 需要 注意 border-radius .box-shadow 和 text-shadow 属性 的 属性 值 顺序 。 


12.4 人 才 招 聘 移 动 互联 网 网 站 设计 实例 


使 用 HTML5 和 CSS3 技术 ,在 人 才 招 聘 计算 机 网 站 基础 上 ,通过 系统 分 析 、 系 统 设计 
和 测试 三 个 步骤 ,可 以 实现 人 才 招 聘 移动 互联 网 的 网 站 设计 。 


12.4.1 系统 分 析 


1. 开发 环境 及 工具 


移动 互联 网 网 站 的 开发 环境 与 计算 机 网 站 相同 ,如 表 12-7 所 示 , 人 才 招 聘 移动 互联 
网 网 站 和 计算 机 网 站 使 用 同一 个 数据 库 。 
表 12-7 移动 互联 网 网 站 开发 环境 表 




















软件 名 称 

Web 服务 器 Apache 

数据 库 MySQL 

集成 开发 环境 Dreamwaver 

测试 工具 Chrome 浏览 器 和 手机 浏览 器 

1 术 中 17B/s ty MM 68% WD 11:28 

2. 首页 概述 ap 
首页 页 面 设计 采用 页 尖 、 内 容 、 页 脚 的 上 、 | 最 新 岗位 





中 \ 下 三 段 式 纵向 布局 ,其 中 页 头 显示 网 站 名 称 “| 合 铝 : 可 
和 L0G0, 内 容 显示 最 新 岗位 信息 ,信息 来 源 于 | 名 :3 
rezp 数据 库 。 页 脚 为 导航 区 ,有 首页 .招聘 信息 、 [公司 名 积 : 工商 前 进去 行 
求职 信息 和 求职 论坛 4 个 链接 。 用 户 上 下 滑动 | 名作: 笔 鲍 会 济 学 + 全 融 
网 页 内 容 时 ,导航 区 始终 锁定 在 显示 屏 底部 ,如 | 


公司 名 称 : 腾讯 总 公司 
图 12-9 所 示 。 岗位 名 称 : 理财 师 
聘任 要求 : 笔试 : 经 济 法 + 财务 管理 




















12.4.2 系统 设计 | 公司 名 称 ， 脆 人 公 司 


: 经 理 助理 
求 : 笔试 : 经 济 学 + 人 力 资源 














人 才 招 聘 网 站 系统 设计 包括 新 建 网 站 、 网 
页 模板 设计 、 网 页 样式 设计 和 首页 设计 4 个 na 
步骤。 








图 12-9 人 才 招 聘 手机 主页 
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1. 新 建 网 站 


人 才 招 聘 手机 网 站 与 计算 机 网 站 访问 相同 的 数据 库 ,但 是 站 点 根 目录 和 URL 不 同 。 

(1) 新 建 服 务 器 站 点 目录 : 在 …xampp\ htdocs 下 新 建文 件 夹 rezpsj ,作为 服务 器 端 人 
才 招 聘 手机 网 站 根 目录 。 

(2) 新 建 本 地 站 点 目录 : 在 D 盘 下 新 建 rezpsj 文件 夹 ,作为 本 地 计算 机 人 才 招 聘 手 
机 网 站 根 目 录 。 

(3) 新 建站 点 : 启动 Dreamweaver, 单 击 “ 站 点 "菜单 一 “新 建站 点 "选项 ,在 “站 点 设 
置 对 象 " 窗 口中 ,输入 “站 点 名 称 ” 为 rczpsj,“ 本 地 站 点 文件 夹 "为 D: \rezpsj\。 

(4) 配置 服务 器 : 单 击 * 站 点 设置 对 象 " 窗 口中 的 “服务 器 "一 ”+ ”按钮 ,输入 “服务 
器 名 称 ”为 “本 地 服务 器 ” ,选择 “连接 方法 "为 “本 地 /网 络 ” ,服务 器 文件 夹 "为 “.…xampp 
\htdocs\rezpsj”,“WEB URL"” 为 “http://localhost/rezpsj” 。 单 击 “ 保 存 " 按 钮 ,选中 “测试 ” 
复 选 框 ,再 单 击 “ 保 存 " 按 钮 。 

(5) 新 建 PHP 网 页 : 单 击 “ 文 件 "菜单 一 “新 建 " 选 项 ,选择 “页 面 类 型 "为 *PHP” , 单 
击 “ 创 建 " 按 钮 。 

(6) 新 建 数据 库 连 接 : 单 击 “ 窗 口 "菜单 一 “数据 库 ” 一 * +" 一 “MYSQL 连接 "选项 ， 
在 “MYSQL 连接 "窗口 中 ,输入 “连接 名 称 ” 为 rezpsj, “MYSQL 服务 器 ”为 localhost,“ 用户 
名 "为 ywy, “密码 "为 ywy211 , 单 击 “ 选 取 " 按 钮 ,选择 数据 库 rczp, 单 击 “ 确 定 ”" 一 “测试 ” 
按钮 ,提示 “成 功 创建 连接 脚本 "时 ,再 单 击 “ 确 定 " 按 钮 。 


2. 网 页 模板 设计 


网 页 模板 通常 包含 网 页 文档 .页 头 LOGO 和 页 脚 版 权 信息 等 固定 不 变 的 内 容 , 其 他 网 
页 可 以 在 网 页 模板 基础 上 修改 完成 。 

(1) 修改 默认 文档 类 型 : 单 击 “ 编 辑 " 菜 单一 “首选 项 参数 "选项 ,“ 分 类 ”选择 “新 建 
文档 ”, “默认 文档 类 型 "选择 “HTLM5”, 如 图 12-10 所 示 。 

(2) 修改 网 页 文档 声明 : 新 建 HTML 文档 , 单 击 工具 栏 * 代 码 " 按 钮 ,修改 < meta > 和 
<title > 标签 ,修改 后 代码 如 下 : 


<!DOCTYPE HIML > 
<! -文档 声明 ,必须 在 HTML 文 档 的 第 一 行 ,web 浏览 器 根据 文档 声明 的 标准 进行 文件 解析 --> 
<html >dhead > 
‘<meta http -equiv ="Content -Type" content ="text/html; charset autf -8" > 
<! -文档 声明 ,通知 浏览 器 准备 发 送 文件 是 文本 型 HIML 文档 ,文档 字符 使 用 UTF -8 编码 --> 
‘<meta name ="viewport" content 一 "width =device -width, user -scalable no, 

initial -scale3.0, mximm -scale3.0, minimm -scale 村 .0" > 
<! -文档 声明 ,指定 布局 视 口 宽度 和 显示 设备 迎 辑 分 辩 率 宽度 一 致 ,缩放 比 为 100% ,不 许 用 户 缩 
放 --> 
<title > 人 才 招 聘 网 </title ></head > qbody ></body ></html > 
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默认 文档 内 : [WE 


默认 扩展 名 到): htnl 
默认 文档 类 型 0TD): [jmb5 











默认 编码 0) [Unicede QWTF-8) 了 

国 当 打开 未 指定 编码 的 现 有 文件 时 使 用 

Unicode 标准 化 表单 F)，[C (规范 分 解 ， 后 跟 规 范 合成 ) a 
园 包 括 Unicode 签名 Co G) 

















国 按 Controlt¥ 组 合 键 时 显示 “新 建文 档 ” 对 话 框 0) 














图 12-10 ”修改 默认 文档 类 型 
(3) 页 头 和 页 脚 设 计 : 页 头 显示 网 站 名 称 和 LOG0O ,页 脚 显示 导航 菜单 ,代码 如 下 : 


<body > header ><hgroup > 

<img alt ="" height ="50px" src ="images/ 人 才 招 聘 logo.gif"> 

<h2 > 人 才 招 聘 </h2 ></hgroup ></header > 

<section class ="section" ></section > 

<footer ><div class =nav" ><ul > 

<1Li ><a href = 入 ><span > 首页 </span ></a></1i> 

<1i style ="position:relative;" ><a href="/rczpsjb/jcbs.php" ><span > 招聘 信息 </span > 
</a> 

< 

<1i ><a href ="/rczpsjb/resume.php" ><span 水 职 信息 </span ></a></1i> 

<1i ><a href ="/rczpsjb/news/" ><span 水 职 论 坛 </span ></a></1i></ul> 

</div ></footer ></body > 


3. 网 页 样式 设计 
在 手机 网 页 设计 中 ,CSS 属性 的 宽度 单位 用 百分比 ,高 度 单位 用 像素 ,代码 如 下 : 


<style type ="text/css" > 





body {margin:0} 

header {width:100% ;height :60px;background: 制 266cc; color: #Eff;} 

h2 {display:inline;text -shadow:2px 2px 8px 硼 OFFFF7} 

h3 {text -shadow:2px 2px 8px ECCC00;} 

. section {width: 100% ; background: 2f2f2; float: left; overflow: auto; text -align: 
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center;} 


-divcontent1, .divcontent2, .divcontent3 {padding:10px;text -align:left;width:90%; 


height: 78px; background: $ee220; border: 1px solid 所 da8cb; margin:0 auto 15px 
auto; 


border -radius:15px; box -shadow:0 0 10px 失 0CCCC; } 
.divcontent?2 {background:#eef94;} 

.divcontent3 {background: 所 3b8f£4;} 
footer {width:100% ;height :50px;background:green;clear:both; } 
-nav {background: 失 09c39;padding: 10px 0 6px 0;width: 100%; position: 

fixed; left: 0; bottom: 0;} 
.nav ul { height: Opx; } 
-nav ul li {float: left;width: 25%; text -align: center; } 
-nav ul 1i span {display: block;color: #¥ff;font -size: 16px;} 
a {color: 拥 00; text -decoration: none;} 


* { padding: 0; margin: 0; list -style: none;font -weight: normal; } 
</style> 


4. 网 页 内 容 设计 


用 < section > 标签 显示 最 新 岗位 ,从 rezp 数据 库 取 数据 。 显 示 最 新 岗位 的 代码 如 下 : 
<section class ="section" ><h3 北新 岗位 </h3 > 

<?php do { ?> 

<div class ="divcontent1l" ><ul > 

<Li 3 公司 名 称 : <?php echo Srow Recordsetgw[' 公 司 名 称 ']; ?></1i > 

<li 疯 位 名 称 : <?php echo $row Recordsetgw[' 岗 位 名 称 ']; ?></1i > 

<i 小 任 要 求 : <?php echo $row_Recordsetgw[' 聘 任 要 求 ']; ?></1i> 

<Li > 人 数 : <?php echo $row Recordsetgw[' 人 数 ']; ?><1i><ul><div> 


<?php } while ( $row Recordsetgw =mysq] fetch assoc ( $SRecordsetgw)); ?> 
</section > 


12.4.3 测试 


计算 机 网 页 只 需要 使 用 计算 机 浏览 器 测试 ,手机 网 页 可 以 通过 计算 机 浏览 器 模拟 或 
直接 使 用 手机 浏览 器 测试 。 打 开 Chrome 浏览 器 ,在 地 址 栏 中 输入 http://localhost/ rczpsj , 
可 以 看 到 手机 网 页 在 计算 机 浏览 器 中 显示 正常 ,如 图 12-11 所 示 。 

按 Fl12 键 ,调整 模拟 器 屏幕 分 辩 率 ,查看 不 同 手机 显示 屏 中 的 显示 效果 。 


习 题 
一 、 填 空 题 
1. 互联 网 分 为 计算 机 互联 网 和 两 种 。 
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10. 
jt 
. 在 CSS3 中 ,设置 。” 属性 可 以 实现 各 种 圆 角 边框 。 


Yi: 


3; 


© | © 192.168.1106/rczp/ 女 | : 


DE 人 才 招聘 | 





最 新 岗位 





公司 名 称 : 工商 前 进 支行 
聘任 要 求 : 笔试 经 济 学 + 爹 融 








公司 名 称 : 工商 前 进 支行 
岗位 名 称 : 岗 前 培训 师 
聘任 要 求 : 笔试 经 济 学 + 金融 








公司 名 称 : 腾讯 总 公司 


: 理财 师 
聘任 要 求 : 笔试 : 经 济 法 + 财务 管理 























图 12-11 使 用 计算 机 浏览 器 查看 手机 网 页 


移动 互联 网 使 用 或 平板 电脑 等 移动 设备 作为 访问 终端 。 
移动 互联 网 访问 的 站 点 可 以 是 专属 _Q@ 站 点 或 采用 _@ 开发 的 Web 站 点 。 





. WAP2.0 网 站 使 用 _ 作为 文档 类 型 。 
. XHTML MP 是 HTMI4.0 的 ” 。 


标准 HTMLS 规范 于 年 10 月 发 布 。 
手机 显示 屏 尺寸 是 指 屏幕 (DD 长 度 ,单位 是 _@) 。 





. _@ 又 称 为 设备 像素 , 指 显 示 器 上 一 个 最 小 的 物理 部 件 ,用 _@ 表示 。 


手机 分 辨 率 是 指 手机 显示 屏 的 ”_ 物理 分 辨 率 。 
像素 密度 是 指 每 _(D 长 度 上 排列 的 _@® 数量 。 
_ 是 指 编程 所 能 控制 的 最 小 显示 单位 。 





在 CSS3 中 ,box-shadow 属性 默认 的 阴影 类 型 为 ” 。 
、 单 选 题 
视网膜 屏 手 机 是 指 手 机 显示 屏 像素 密度 在 ( )PPI 以 上 。 
A. 200 B. 300 C. 400 D. 500 


手机 物理 分 辩 率 为 640 x960 , 逮 辑 分 辩 率 为 320 x480 ,手机 设备 像素 比 为 ( 和 
A. 1 B. 2 C. 3 D. 4 


手机 物理 分 辩 率 为 1242 x2208 ,逻辑 分 辩 率 为 414 x736 ,手机 像素 密度 为 ( js 
A. 326 B. 401 C. 300 D. 501 
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4. 人 ) 是 显示 设备 上 一 个 具有 特定 显示 功能 的 矩形 区 域 。 
A. 像素 B. 视 口 C. 分 辩 率 D. 手机 显示 屏 
5. 手机 布局 视 口 宽度 通常 为 ( )PX。 
A. 320 B. 480 C. 980 D. 1024 
6. 在 HTML4 规范 中 ,使 用 ( ) 标 签 定义 文档 中 的 分 区 或 节 。 
A. <div > B. <table > C. <body> D. <font> 
7. 在 HTMLS 规范 中 ,使 用 ( ) 标 签 定义 图 形容 器 。 
A. <embed> B. <canvas> C. <input> D. <video > 
8. 在 HTMLS 规范 中 ,使 用 ( ) 标 签 定义 外 部 的 可 交互 的 内 容 或 插件 。 
A. <audio> B. <canvas> C. <embed > D. <video > 
9. 在 HTMLS 规范 中 ,使 用 ( ) 标 签 定义 网 页 或 区 段 (内 容 块 ) 的 页 眉 。 
A. <header> B. <nav> C. <footer> D. <article > 
10. 在 HTMLS 规范 中 ,使 用 ( ) 标 签 定义 网 页 的 导航 链接 区 域 。 
A. <header > B. <nav > C. <footer > D. < article > 
11. 在 HTMLS 规范 中 ,使 用 (  ) 标 签 定义 网 页 的 页 脚 区 域 。 
A. <header > B. <figure > C. <input > D. <footer > 
12. 在 CSS3 中 ,设置 ( ) 属性 可 以 实现 元 素 块 阴影 效果 。 
A. box-shadow B. border-radius C. text-shadow D. border-shadow 
13. 在 CSS3 中 ,设置 ( ) 属 性 可 以 实现 文本 阴影 效果 。 
A. box-shadow B. border-radius C. text-shadow D. border-shadow 
三 、 多 选 题 
1. 手机 的 软 硬 件 与 计算 机 有 明显 差别 的 是 ( ) 。 
A. 中 央 处 理 器 B. 内 存 C. 显示 设备 
D. 输入 设备 E. 操作 系统 
2. XHTML MP 文档 与 HTML 文档 的 主要 区 别 是 (  )。 
A. 元 素 必 须 被 正确 地 藤 套 B. 元 素 必 须 被 关闭 
C. 标签 名 必须 用 小 写字 母 D. 文档 必须 拥有 根 元 素 
E. 单 标签 被 取消 F. 框架 集 .框架 和 表格 等 标签 被 删除 
3. HTML5 的 主要 改变 有 (  ” )。 
A. 删除 < frame > 标签 B. 删除 <font > 标签 
C. 新 增 < video > 标签 D. 新 增 < audio > 标签 
E. 新 增 < canvas > 标签 F. 删除 < input > 标签 
4. 关于 计算 机 网 页 和 手机 网 页 ,下 列 说 法 正确 的 是 ( ) 。 
A. 计算 机 网 页 无 法 使 用 手机 浏览 器 打开 
B. HTMLS 编写 的 手机 网 页 可 以 使 用 计算 机 浏览 器 打开 
C. 手机 网 页 只 能 是 静态 网 页 
D. 手机 网 页 可 以 访问 数据 库 
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E. 手机 网 页 无 法 播放 视频 
5. 手机 网 页 设计 时 的 视 口 有 ( )。 


A. 布局 视 口 B. 视觉 视 口 C. 理想 视 口 
D. 逻辑 视 口 E. 物理 视 口 

6. HTMLS 的 结构 标签 有 ( ” )。 
A. <header> B. <hgroup > C. <nav> D. <footer > 
E. <embed > F. <canvas> 

7. HTMILS 的 < input > 标签 类 型 有 ( ss 
A. email B. url C. audio D. number 
E. range F. date 

8. 在 CSS3 中 ,关于 border-radius 属性 设置 ,下 列 方法 正确 的 是 ( )'s 
A. 可 以 不 设置 属性 值 B. 可 以 只 设置 1 个 值 
C. 可 以 只 设置 2 个 值 D. 可 以 只 设置 3 个 什 


E. 可 以 只 设置 4 个 值 
9. 关于 物理 像素 ,下 列 说 法 正确 的 是 ( )。 
A. 相同 的 设备 ,每 个 物理 像素 的 长 度 相同 
B. 相同 的 设备 ,每 个 物理 像素 的 长 度 可 以 不 同 
C. 不 同 的 设备 ,每 个 物理 像素 的 长 度 相同 
D. 不 同 的 设备 ,每 个 物理 像素 的 长 度 可 以 不 同 
E. 物理 像素 与 设备 无 关 
10. 关于 逻辑 分 辨 率 ,下 列 说 法 正确 的 是 (  )。 
A. 计算 机 显示 器 的 1 个 逻辑 像素 一 定 等 于 1 个 物理 像素 
B. 计算 机 显示 器 的 逻辑 分 辨 率 可 以 设 定 
C. 手机 显示 屏 的 迎 辑 分 辨 率 可 以 设 定 
D. 手机 显示 屏 的 迎 辑 分 辩 率 和 物理 分 辩 率 一 定 相同 
E. 手机 显示 屏 的 逻辑 分 辨 率 和 物理 分 辨 率 可 以 不 同 
11. 关于 手机 网 页 设计 ,下 列 说 法 正确 的 是 ( ) 。 
A. 手机 网 页 只 能 使 用 HTMLS 标准 设计 
B. 用 HTMLS 设计 的 网 页 ,只 能 在 手机 上 浏览 
C. 手机 网 页 和 计算 机 网 页 可 以 访问 相同 的 数据 库 
D. 可 以 使 用 Dreamweaver 开发 手机 网 页 
E. 手机 网 页 不 支持 CSS 技术 
12. 在 CSS3 中 ,box-shadow 属性 值 不 能 省 略 的 是 ( ”)。 
A. h-shadow B. v-shadow C. blur 
D. spread E. color F. inset 
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1. 移动 互联 网 有 哪些 特点 ? 

2. 使 用 手机 浏览 网 页 和 使 用 计算 机 浏览 网 页 在 操作 习惯 上 有 哪些 不 同 ? 

3. 如 何 区 分 移动 互联 网 网 站 域名 和 计算 机 网 站 域名 ? 

4. 为 了 避免 网 页 表单 提交 数据 时 ,手机 网 络 信号 突然 中 断 ,HTMLS 规范 使 用 了 什么 
新 技术 ? 

5. 如 何在 手机 网 页 中 使 用 GPS 定位 功能 ? 
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BBS 系统 的 程序 设计 


BBS( Bulletin Board System ,电子 公告 牌 系统 ) 提供 了 一 种 基于 Web 的 信息 服务 ,是 一 
种 浏览 和 发 布 信息 的 互联 网 平台 。 

本 章 引 导读 者 用 Dreamweaver 操作 结合 标记 语言 和 PHP 程序 设计 等 技术 设计 一 个 较 
完整 的 网 站 ,使 读者 能 够 掌握 设计 网 站 的 基本 过 程 和 方法 ,侧重 解决 如 下 问题 

(1) 如 何 进行 系统 设计 和 分 析 ? 

(2) 如 何 规划 网 站 目录 ? 

(3) 如 何 设计 人 机 交互 网 页 ? 

(4) 如 何 设 计 信 息 浏览 网 页 ? 

(5) 如 何 发 布 和 推广 网 站 ? 


13.1 系统 分 析 与 设计 


人 才 招 聘 BBS 具有 用 户 注册 ,登录 .信息 浏览 发表 主题 和 信息 管理 等 功能 。 

1. 系统 目标 

系统 主要 目标 是 针对 系统 的 功能 及 其 运行 效果 的 期 望 和 要 求 ,实现 如 下 目标 : 

(1) 系统 采用 B/S 架构 ,有 注册 用 户 和 游客 两 种 角色 ; 

(2) 游客 只 具有 浏览 招聘 信息 和 信息 论坛 的 权限 ; 

(3) 注册 的 用 户 可 以 浏览 信息 以 及 发 表 ,管理 主题 ; 

(4) 具有 搜索 论坛 信息 的 功能 。 

2. 系统 功能 结构 

人 才 招 聘 BBS 的 用 户 角 色 有 游客 和 用 户 ,根据 角色 不 同 ,系统 功能 如 图 13-1 所 示 。 
3. 系统 开发 环境 及 工具 


(1) 操作 系统 : Windows 7 64 位 版 本 。 
(2) 服务 器 平台 : XAMPP 集成 的 Apache Web 服务 。 


王 一 一 一 一 一 一 一 一 一 








人 才 招 聘 BBS 











































































































游客 登录 用 户 登 录 
训 浏 注 发 回 管 ] 
览 览 册 布 复 理 | 1 
招 论 新 论 论 论 | | 
聘 3 用 坛 坛 坛 | | 
信 信 由 EF 主 主 | 1 
息 奶 题 题 题 ) 
图 13-1 人 才 招 聘 BBS 系统 功能 结构 


(3) 软件 开发 环境 及 语言 : Dreamweaver .PHP 和 HTML。 
(4) 数据 库 管理 系统 : MySQL。 
(5) MySQL 可 视 化 管理 软件 : PHPMyAdmin。 


4. 网 站 的 文件 及 目录 规划 


在 开发 设计 之 初 ,首先 需要 在 XAMPP 的 安装 目录 下 “ …\XAMPP\Htdocs\RCZP\” 中 
创建 BBS 文件 夹 ,然后 在 其 下 创建 用 于 存储 各 类 文件 的 子 文件 夹 , BBS 系统 包含 的 主要 
文件 名 与 功能 如 表 13-1 所 示 。 


表 13-1 系统 规划 的 文件 功能 表 





















































文件 目录 文件 名 称 功能 说 明 

..\BBS Index. PHP 系统 首页 

Jieshao. HTML 人 才 招 聘 BBS 简介 

Left. HTML 系统 左 导航 页 面 

Zhuce. HTML 系统 用 户 注册 
..\BBS\Pages 

Zhpxx. HTML 系统 框架 结构 

Top. PHP 主页 标题 

Bbszpxx. PHP 招聘 信息 浏览 
..\BBS\Images Imgshouye. JPG 系统 首页 图 片 
SS Navi. CSS 系统 导航 页 样式 表 

Top. CSS 系统 标题 页 样式 表 

ConnDB. PHP 数据 库 连接 

Chaxun. PHP 招聘 信息 查询 
..\BBS\Process Logout. PHP 用 户 退 出 

Dlchuli. PHP 用 户 登录 身份 验证 

Zhucchuli. PHP 注册 系统 用 户 的 处 理 
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文件 目录 文件 名 称 功能 说 明 

Ltindex. PHP 信息 论坛 主页 
Ltguanli. PHP 主题 管理 页 
Zijzhuti. PHP 发 表 主题 

..\BBS\XXLT 
Xgzhuti. PHP 修改 主题 内 容 处 理 文件 
Sczhuti. PHP 删除 主题 处 理 文件 
Ltsearch. PHP 搜索 主题 

..\BBS\Connections RCZP. PHP 论坛 模块 记录 集 绑 定数 据 库 文件 


5. 定义 系统 站 点 
利用 Dreamweaver 创建 “人 才 招 聘 BBS 系统 "站 点 BBS , 主要 参数 如 表 13-2 所 示 。 


表 13-2 站 点 设置 参数 表 














参数 名 参数 值 参数 名 参数 值 
站 点 名 称 BBS 服务 器 文件 夹 | ..Xampp\Htdocs\RCZP\BBS 
本 地 站 点 文件 夹 et \ Hoes V ECAP | atiURi HTTP://Localhost/ BBS 
服务 器 名 称 LocalHost 服务 器 模型 ”| PHP MySQL 
连接 方法 本 地 /网 络 











13.2 用户 注册 与 登录 网 页 设计 


系统 首页 是 用 户 登录 与 注册 页 面 ,引导 用 户 进 入 系统 。 
登录 页 面 提供 用 户 的 登录 验证 ,游客 登录 和 用 户 注册 三 项 功能 ,效果 如 图 13-2 所 示 。 


13.2.1 登录 页 面 设 计 过 程 


于 


登录 页 面 设计 


登录 页 面 主要 用 HTML 的 < Form > 表单 标签 实现 ,设计 步骤 如 下 : 


(1) 


通过 Windows 操作 ,将 相关 资源 文件 (如 Imgshouye. JPG ) 复制 到 对 应 文件 夹 


(如 .. \BBS\Images) 中 。 


(2) 
右 击 菜 让 





在 Dreamweaver 中 ,选择 “BBS” 为 当前 站 点 ,从 “文件 "面板 的 “本 地 文件 " 窗 格 的 
和 中 选择 “新 建文 件 " 选 项 ,文件 命名 为 Index. PHP。 
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图 13-2 ”系统 登录 页 效果 


(3) 双击 mdex. PHP ,在 “设计 "模式 下 , 单 击 “ 插 入 "菜单 一 “表格 "选项 ,在 “表格 "对 
话 框 中 , 行 数 设置 为 1 , 列 数 设置 为 2, 单 击 “ 确 定 ” 按 钮 。 
(4) 将 Images\Imgshouye. JPG 文件 拖 忠 到 第 1 列 中 ,适当 调整 图 像 大 小 和 位 置 。 
(5) 光标 置 于 第 2 列 中 , 单 击 “ 插 入 "菜单 一 “表格 "选项 ,在 “表格 "对 话 框 中 , 行 数 设 
置 为 2, 列 数 设置 为 1 , 单 击 * 确 定 "按钮 。 
(6) 在 新 表格 的 第 1 行 中 输入 文字 * 登 录 到 人 才 招聘 BBS 站 ” ;在 第 2 行 的 代码 窗口 
中 ,编写 程序 Index. PHP 的 部 分 代码 如 下 : 
<Form Name ="Form?2" Method ="Post" Action ="Process/Dlchuli .PHP" > 
<! -Action 指定 后 台 处 理 程序 是 站 点 Process 文件 夹 下 的 Dlchuli .PHP 文 件 --> 
也 站 号 : <Input Type ="Text" Name "Account"/ ></P> 
也 北 码 : <Input Type ="Password" Name ="Pw" / ></P> 
<Input Type ="'Submit" Name "D1" Value "登录 "/ > 
<Input Type "Button" Name 了 "Yk" Value 二 游客" 
Onclick ="Javascript :Window.O0pen ('Pages/Zhpxx.HIML',' Self')"/ > 
<! -- 调 用 javascript 角 本 ,以 游客 角色 进入 到 站 点 Pages 文件 夹 下 的 Zhpxx.HIML 系统 主页 
面 --> 
<Input Type 2"Button" Name ="Zc" Value =" 注册 " 
Onclick ="Javascript :Window.Open ('Pages/Zhuce.HIML','_ Self')"/ > 
<! 一 调用 javascript 角 本 ,进入 到 站 点 Pages 文件 夹 下 的 zhuce.HTML 用 户 注册 页 面 --></ 
Form > 
当 浏 览 网 页 时 ,用 户 输入 账号 和 密码 后 , 单 击 * 登 录 " 按 钮 会 执行 Action 属性 设置 的 
程序 Process\Dlchuli. PHP ,判断 用 户 角色 后 实现 页 面 跳 转 ; 单 击 “游客 "或 “注册 ”按钮 都 
将 触发 Onclick 事件 ,打开 对 应 的 网 页 文件 Zhpxx. HTML 或 Zhuce. HTML。 


2. 登录 信息 处 理 的 程序 设计 


从 “文件 "面板 的 “本 地 文件 " 窗 格 中 选中 Process 文件 夹 , 从 右 击 菜单 中 选择 “新 建文 
件 ” 选 项 ,文件 命名 为 Dichuli. PHP, 双 击 打开 该 文件 ,在 “代码 "视图 下 ,编写 程序 如 下 : 


<?PHP $Account =$ POST["Account"]; ”// 获取 表单 里 的 账号 值 
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S$Pw =$ POST["Pw"]; // 获取 表单 里 的 密码 值 


Require ("ConnDB. PHP") ; // 连接 到 MysQL 里 的 RCZP 数据 库 
SSQL "Select * From YPRYB Where 身份 证 号 =' $Account'"; 
$result -MySQL Query ( $sq1); // 发 送 SQL 语句 


Srow -MySQL Fetch Assoc( $result); SName =$Row[' 姓 名 ']; 
If (Count ( $SRow) =-0 11 Row[' 密 码 '] ! =$pw) 
Echo " <Script Aocation.Href ="'../Index.PHP'; </Script >"; 
// 账 号 或 密码 错 则 定位 到 登录 页 面 
Else { Session Start (); // 启动 Session 
$SessionId =Session Id(); 
SNow Date('y mm-dh:i:s',Time()); $ SESSION[' 身 份 证 号 '] =$Account; 
$_ SESSION[' 姓 名 '] =SNamey $ SESSION['SessionId'] =$SessionId; 
Echo " <Script Aocation.Href ='../Pages/Zhpxx.HIML'; </Script >"; 
// 用 户 账号 和 密码 正确 系统 跳 转 到 Pages 文件 夹 下 的 Zzhpxx.HIML 主页 面 } ?> 


3. 连接 数据 库 的 程序 设计 


ConnDB. PHP 文件 是 连接 MySQl 数据 库 的 程序 ,由 于 系统 中 多 处 涉及 连接 数据 库 的 
操作 ,为 了 减少 代码 重复 ,将 连接 数据 库 的 代码 封装 在 该 文件 中 ,保存 在 站 点 Process 文件 
夹 下 ,PHP 程序 如 下 : 


<?PHP $conn MySQL PConnect ("LocalHost"," ywy", "ywy211"); 
MySQL Select DB ("rczp"); MySQL Query ("Set Names 'utf8'"); ?> 


13.2.2 注册 页 面 设计 


系统 的 注册 页 面 主要 实现 人 才 招 聘 BBS 访客 填写 证 件 号 ,姓名 和 密码 ,注册 成 为 系 
统 用 户 以 获得 更 多 的 操作 权限 。 


1. 注册 页 面 设计 


在 Dreamweaver 中 ,选择 “BBS ”为 当前 站 点 ,从 “文件 "面板 的 “本 地 文件 " 窗 格 中 选择 
Pages\ Zhuce. HTML 文件 ,在 “代码 "视图 下 ,将 光标 定位 在 < Body > 标记 内 ,编写 表单 代 
人 码 如 下 : 


<Eorm Name ~"Form" Method ="Post" Action ="Process/Zhcchuli .PHP" > 
<! --action 指定 处 理 程序 Process 文件 夹 下 的 Zhcchuli .PHP 文 件 --> 
< 也 淘 份 证 号 : <Input Type ="Text" Name ="Id"/ ></P> 
< 姓名 : <Input Type ="Text" Name ="Name"/ ></P> 
也 帝 码 : <Input Type =-"Password" Name "Pw" /></P> 
< ><Input Type "Submit" Name ="D1" Value »" 注 册 "/ ></P> 
</Eorm> 


用 户 输入 的 数据 需要 存储 到 数据 中 ,由 Action 属性 设置 的 程序 Zhucchuli. PHP 完成 ， 
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运行 效果 如 图 13-3 所 示 。 
2. 注册 程序 设计 


选中 Process 文件 夹 ,从 右 击 菜单 中 选择 “新 建文 件 " 选 
项 ,文件 命名 Zhucchuli. PHP, 双击 Zhucchuli. PHP ,在 “代码 ” 
视图 下 编写 如 下 代码 : 





opHp Require ("ConnpB.PHP"); // 连接 数据 库 图 133 注册 页 的 运行 效果 
$Id=$_POST['Id']; // 身份 证 号 值 赋 
给 $Id 
SName =$ POST['Name']; // 姓名 值 赋 给 SName 
SPw=$S POST['Pw']; // 密码 值 赋 给 SPw 
SSQL "Insert Into YPRYB (身份 证 号 ,姓名 ,密码 ) Values (' $Id', ' SName', ' Spw')"; 
// 将 值 插入 到 数据 表 YPRYB 
$result MySQL Query( $5q1);  // 发 送 SQL 的 Insert 语句 
Header ("Location: ../Index.PHP"); // 注册 成 功 ,页 面 自动 跳 转 到 用 户 登录 页 面 ?> 


13.3 系统 主页 设计 


系统 主页 是 用 户 登录 到 系统 后 进行 工作 的 界面 ,合理 有 效 地 规划 界面 区 域 是 系统 主 
页 设计 的 主要 任务 。 人 才 招 聘 BBS 系统 主页 面 采 用 HTML 的 框架 技术 ,分 成 三 个 区 域 ; 
顶 区 、 左 区 和 浏览 区 ,结构 如 图 134 所 示 。 





项 
左 区 | 浏览 区 


图 134 主页 框架 结构 


风 














13.3.1 主 框 架设 计 


主页 面 首先 从 框架 集 开始 设计 ,再 设计 三 个 区 域 对 应 的 网 页 文件 。 利 用 HTML 的 框 
架 技 术 , 实 现 主页 面 的 区 域 划分 ,从 “文件 "面板 的 “本 地 文件 " 窗 格 中 选中 Pages 文件 夹 ， 
从 右 击 菜单 中 选择 “新 建文 件 ” 选 项 ,文件 命名 为 Zhpxx. HTML, 双击 打开 Zhpxx. HTML 在 
“代码 "视图 下 编写 如 下 代码 : 


<HIML > <Head > Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; Charset =UTF -8"/ 
3 
<Title > 人 才 招 聘 BBS </Title ></Head > 
<Erameset Rows ="105, * " Cols="*" > <! 一 -定义 框架 开始 --> 
<Erame Src ="Top.PHP" Name ="Top" Scrolling ~"No"/ > 
<! - -定义 顶 区 框架 链接 的 源 文 件 为 Top.PHP 滚动 条 属性 值 为 No --> 
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<Erameset Rows ="* "Cols 汪 113,*# "> 
< 上 rame Src ="Left .HIML" Name 一 Left" Scrolling ="No" Noresize /> 
<! -定义 左 区 链接 的 源 文件 为 Left .HIML --> 
<Frame Src ="Jieshao.HIML" Name ~"Main" Scrolling ="Yes" Noresize /> 
<! -定义 浏览 区 链接 的 源 文件 为 jieshao.HIML -一 > 
</Frameset > 
</Frameset ><! -- 定 义 框架 结束 --></HIML > 


13.3.2 顶 区 相关 网 页 设计 


1. 项 区 网 页 设计 


设计 顶 区 网 页 文件 ,在 “文件 "面板 的 “本 地 文件 " 窗 格 的 Pages 文件 夹 中 ,从 右 击 菜 
单 中 选择 “新 建文 件 " 选 项 ,文件 命名 为 Top. PHP ,双击 Top. PHP ,在 “代码 "视图 下 编写 如 
下 代码 : 


<HIML ><Head > 

<Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; Charset =UTF -8" /> 

<Title > 人 才 招 聘 BBS </Title > 

<Link Href 2"CSS/Top.CSs" Rel 2"Stylesheet" ><! - 马 | 入 CSS 文件 Top.CSs --></Head > 
<Body > Div Class = Ra" ><! - -插入 Div 标 签 CSs 类 别 应 用 样式 A--> 


人 才 招 聘 BBS </Div > 
<Div class ='Info' ><! -- 插 入 Div 标 签 CSs 类别 应 用 样式 Info --> 
<?PHP Session Start (); // 启动 会 话 

If (Isset ($ SESSION[" 姓 名 '])) // 分 析 用 户 角色 


Echo $ SESSION[' 姓 名 7] ."', 你 好 "'; // 显示 用 户 姓名 
Else Echo ' 游 客 , 你 好 '; ? > 
<A Href "Process/Logout .PHP" > 退出 YA> // 单 击 退 出 ,执行 Logout.PHP 清 除 Session 
</Div ></Body ></HIML > 


2. 项 区 样式 设计 


代码 中 引入 的 Top. CSS 样式 表 文 件 保存 在 BBS 站 点 中 的 CSS 文件 夹 下 ,用 于 规范 
Top. PHP 的 显示 效果 ,编写 的 代码 如 下 : 


.A { Font -Family: "方正 姚 体 "; Font -Size: 57px; Font -Weight: bolder; 
Color: 提 00; Background -Color: €CF; Text Align: Center; } 
.Info{ Float:Right; } 


3. 用 户 退 出 系统 的 程序 设计 


代码 中 链接 的 Logout. PHP 文件 保存 在 BBS 站 点 中 的 Process 文件 夹 下 ,用 于 用 户 注 
销 并 返回 到 登录 页 面 ,编写 的 代码 如 下 : 
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<?PHP Session Start () 7 // 启动 会 话 
If (IsSet ($ SESSION[" 身 份 证 号 '])) 
{ $ SESSION Array(); // 删除 $ SESSION 中 全 部 元 素 
// 如 果 存 在 一 个 会 话 COOKIE, 通 过 将 到 期 时 间 设 置 为 之 前 工 个 小 时 从 而 将 其 删除 
If (Isset ( $ COOKIE [Session Name () ])) Setcookie (Session Name ()，' ,Time () — 
3600) 


Session Destroy(); ”// 注销 会 话 ”} // 使 浏览 器 重 定向 到 另 一 个 页 面 
Echo " <Script Mindow.Open ('. ./Index.PHP'，' Top') </Script >";?> 


13.3.3 无 区 网 页 设计 


1. 左 区 网 页 设计 


左 区 主要 由 链接 相关 网 页 文件 的 代码 组 成 ,用 于 显示 系统 导航 条 (如 论坛 首页 .招聘 
信息 等 ) 和 定义 浏览 区 要 显示 的 网 页 文件 (如 Jieshao. HTML、Bbszpxx. PHP 等 )。 从 “ 文 
件 ” 面 板 的 “本 地 文件 " 窗 格 中 选中 Pages 文件 夹 ,从 右 击 菜单 中 选择 "新 建文 件 " 选 项 , 文 
件 命名 为 Left. HTML。 双 击 Left. HTML ,在 “代码 "视图 中 编写 如 下 代码 ; 


<HTML ><Head > 
<Meta HTTP -了 qujv ="Content -Type" Content ="Text/HIML; Charset =UTF -8" /> 
<Title 涝 单 导航 页 </Title > 
<Link Href ="../CSS/Navi .Css" Rel 2"Stylesheet" ><! -引入 Css 文件 Navi --></Head > 
<Body ><p > 必 Href ="Jieshao.HIML" Target -Main ><! - -定义 链接 文件 打开 目标 在 浏览 区 --> 
<Span Class ="B" > 论坛 首页 </Span ><! - -应 用 样式 表 文 件 的 类 别名 称 为 B --></A><Br > 
</P> 
> Href -="Bbszpxx.PHP" Target -Main ><! - -定义 链接 文件 打开 目标 在 浏览 区 --> 
<Span Class ="B" :招聘 信息 </Span ></R><Br ></P> 
<> 人 Href 二 ../XXLT/Ltindex.PHP" Target Main > 


<! - -定义 链接 文件 打开 目标 在 浏览 区 --><Span class ="B" > 信息 论坛 /Span ></RA><Br > 
</P> 
</Body ></HIML > 


2. 左 区 样式 设计 
Navi. CSS 保存 在 CSS 文件 夹 ,用 于 规范 页 面 内 容 的 显示 效果 ,代码 如 下 ; 


.B { Font -Size: 20px; Text Align: Center; } 


13.3.4 浏览 区 网 页 设计 


浏览 区 用 于 显示 左 区 中 当前 链接 的 网 页 ,在 用 户 没 有 单 击 任何 链接 前 ,用 于 显示 默认 
网 页 (如 Jieshao. HTML)。 从 “文件 ”面板 的 “本 地 文件 " 窗 格 中 选中 Pages 文件 夹 , 从 右 击 
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菜单 中 选择 “新 建文 件 ” 选 项 ,文件 命名 Jieshao. HTML。 双 击 Jieshao. HTML 在 “代码 ” 视 
图 下 编写 如 下 代码 : 


<HIML ><Head > 
<Meta HTTP -了 qujiv ="Content -Type" Content ="Text/HIML; Charset -UTF -8" /> 
<Title >BBS 介绍 </Title ></Head > 
<Body ><Div>< Align "Center" 次 迎 访问 人 才 招 聘 BBS 站 ! </P> 
< Align "Center" > 在 招聘 信息 页 面 里 可 以 浏览 发布 .删除 招聘 信息 ; wwP> 
< Align ="Center" > 在 信息 论坛 页 面 里 可 以 浏览 ,发表 .回复 .修改 .删除 文章 。 </P> 
</Div ></Body ></Html > 


保存 程序 文件 ,运行 Zhpxx. HTML 文件 ,效果 如 图 13-5 所 示 。 





幸运 .你 好 退出 






欢迎 访问 人 才 招聘 BBS 站 ! 









在 招聘 信息 页 面 里 可 以 浏览 发布、 删除 招聘 信息 ; 
信息 论坛 页 面 里 可 以 浏览 发表、 回复 修改、 删除 文章 。 _ 





图 13-5 系统 主页 运行 效果 


13.4 招聘 信息 功能 模块 设计 


招聘 信息 模块 主要 包括 招聘 信息 的 浏览 ,发布 ,删除 等 功能 ,其 中 用 户 以 游客 角色 登 
录 时 只 有 信息 浏览 的 功能 。 

用 户 单 击 主页 面 导航 “招聘 信息 ” ,链接 到 BBS 站 点 的 Pages 文件 夹 下 的 Bbszpxx. 
PHP, 系统 进入 到 招聘 信息 功能 模块 的 页 面 , 在 该 页 面 内 可 以 实现 招聘 信息 的 浏览 。 


1. 招聘 信息 页 面 设计 


该 模块 主要 是 对 数据 库 表 进行 查询 的 操作 ,在 招聘 信息 显示 浏览 区 ,通过 提取 岗位 表 
中 岗位 名 称 公司 名 称 、 人 数 笔试 日 期 .聘任 要 求 这 五 列 字段 的 记录 ,用 设计 表格 的 方法 
来 展示 页 面 信息 。 

在 Dreamweaver 中 ,选择 “BBS" 为 当前 站 点 ,从 “本 地 文件 "面板 选中 Pages 文件 夹 , 右 
击 选 择 “ 新 建文 件 ” 选 项 ,文件 命名 为 Bbszpxx. PHP。 选 中 Bbszpxx. PHP 双击 ,该 文件 出 现 
在 Dreamweaver 编辑 区 域内 ,在 “代码 ”视图 下 编写 如 下 代码 : 


<HIML ><Head > Meta HTTP -Equiv ="Content -Type" Content ="Text/HIML; Charset =UTF -8"/ 
> 
<Title 沼 聘 信息 显示 </Title ></Head > 


(4 。 基 于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


<Body > <Table Border ="1" Class ~"Table Table -Hover Table Bordered" > 
<Tr Align ="Center" Walign ~“"Middle" > 
<Th idth 14%$" > 岗位 名 称 <Th width ="26%" > 公司 名 称 
<Th Width 二 "77%" > 人 数 <Th Width "16%$" 省 试 日 期 
<Th Wiqgth "37%" 小 任 要 求 </Tr > 
<! -- 定 义 表 格 文件 用 于 显示 招聘 信息 数据 --> 
<?PHP Foreach (ShowContent () Rs SRow) // 记录 集 写 人 到 数组 
{ ?><Tr Align ="Center" Valign ="Mniddle" > 
<Td Height "20" Align "Left" ><?PHP Echo 人 ow[" 岗 位 名 称 "] ; ?> 
<Td Height 2"25" Align ="Left" ><?PHP Echo $Row[" 公 司 名 称 "]; ?> 
<Td Height ="20" Align —"Left" Valign "Middle" ><?PHP Echo SRow[" 人 数 "1]7 ?> 
<Td Height ="20" Align ="Teft" ><?PHP Echo SRow[" 笔 试 日 期 "];? > 
<Td Height ="20" Align "left" ><?PHP Echo 入 ow[" 聘 任 要 求 "]; ?></Tr > 
} ?></Table ></Body > </HIML > 


将 以 上 代码 保存 在 文件 Bbszpxx. PHP 中 ,运行 效果 如 图 13-6 所 示 。 





岗位 名 称 。 公司 名 称 人 数 笔试 日 期 


行政 安宁 软件 公司 7 2017-07-22 
会 计 工商 前 进 支行 3 2017-07-19 
教师 吉林 大 学 经 济 学 院 2 2017-06-16 





图 136 招聘 信息 页 面 运 行 效果 


2. 招聘 信息 处 理 的 程序 设计 

招聘 信息 的 数据 存储 在 RCZP 数据 库 的 GCWB 表 , 系 统 运行 过 程 中 会 读 取 该 表 , 因此 
开发 成 独立 的 Chaxun. PHP 文件 ,方便 程序 间 的 调用 。 

在 Dreamweaver 中 ,选择 “BBS” 为 当前 站 点 ,选中 “本 地 文件 ”Process 文件 夹 , 右 击 选 
择 “ 新 建文 件 ” ,命名 为 Chaxun. PHP。 双 击 该 文件 ,文件 出 现在 Dreamweaver 编辑 区 域内 ， 
在 “代码 "视图 下 ,编写 如 下 代码 实现 对 GWB 表 数 据 集 的 查询 。 


<?PHP 

Function ShowContent () // 用 于 显示 所 有 的 招聘 文章 

{ Require ("ConnDB.PHP") ; // 引入 connpB.PHP 创建 数据 库 连 接 
SSQL Select * From GWB Order By 笔试 日 期 Desc"; ”// SQL 语句 字符 串 
SCount =0; // 用 于 计算 招聘 记录 的 数量 
Sarr =array() // 存放 记录 信息 的 数组 
IE( $result MySQL Query ( $5q1)) // 执行 查找 操作 得 到 所 有 文章 列表 


While( $row = MySQL Fetch Assoc( $result)) $arr[ $count ++] =$row; 
Return $Arr; } ?> 


上 述 代 码 中 对 数据 表 GWB 的 查询 操作 封装 到 了 函数 ShowContent( ) 中 ,其 中 引入 
ConnDB. PHP 文件 中 连接 数据 库 的 代码 。 
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保存 以 上 操作 ,完成 招聘 信息 功能 模块 部 分 的 程序 设计 。 

Mysql_Query( ) 函数 执行 某 个 针对 数据 库 的 查询 ,是 PHP 中 与 数据 库 交 互 的 一 个 方 
法 ,主要 负责 执行 已 经 定义 好 的 SQL 语句 ,进而 对 数据 库 表 的 数据 进行 增加 删除、 修改 、 
查询 等 操作 ,并 返回 满足 条 件 的 结果 集 。 

Mysql_Fetch_Assoc( ) 函数 的 作用 是 从 结果 集中 取得 一 行 作为 关联 数组 ,方便 开发 者 将 
数据 库 表 中 的 数据 以 数组 的 形式 取出 。 通 常 与 Query( ) 函数 组 合 使 用 ,并 返回 结果 集 。 

Mysql_Resul_Free( ) 函数 的 作用 是 释放 结果 内 存 。 上 述 代码 中 ,在 执行 Select 语句 
后 ,结果 集会 存放 在 内 存 中 ,而 通过 该 函数 来 释放 内 存 资源 。 如 果 成 功 ,返回 True; 如 果 
失败 , 则 返回 False。 


13.5 ”信息 论坛 功能 模块 设计 


通过 Dreamweaver 开发 工具 结合 PHP 程序 设计 语言 ,进行 信息 论坛 模块 的 设计 ,相关 
的 PHP 程序 文件 和 页 面 文件 ,保存 在 BBS 站 点 XXLT 文件 夹 里 。 


13.5.1 数据 库 连 接 设置 过 程 


在 Dreamweaver 开发 环境 中 ,为 BBS 站 点 设置 数据 连接 ,目的 是 论坛 功能 模块 能 够 访 
问 数据 表 ,操作 过 程 如 下 。 

(1) 选择 “BBS "站 点 ,从 “文件 "面板 的 “本 地 文件 "选中 XXLT 文件 夹 , 右 击 选择 “新 
建文 件 ” ,文件 命名 为 Ltindex. PHP 双击 左 键 ,该 文件 出 现在 Dreamweaver 编辑 区 域内 。 

(2) 在 Dreamweaver 菜单 上 选择 “窗口 "一 “数据 库 ” ,在 “数据 库 ” 面 板 中 , 单 击 国 按 
钮 ,并 选择 “MySQL 连接 ”。 

(3) 在 “MySQL 连接 ”对 话 框 中 ,输入 如 表 13-3 所 示 的 参数 值 。 单 击 “ 选 取 ” 按 钮 , 浏 
览 MySQL 服务 器 上 保存 的 数据 库 并 选择 已 经 创建 的 RCZP 数据 库 。 

表 13-3 ”数据 库 连 接 参数 值 表 











参数 名 称 参数 值 参数 名 称 参数 值 
连接 名 称 RCZP 密码 Ywy211 
MySQL 服务 器 LocalHost 数据 库 RCZP 
用 户 名 ywy@ LocalHost 











(4) 单 击 * 测 试 "按钮 ,如 果 与 MySQL 数据 库 的 连接 正确 , 则 会 显示 “成 功 创建 连接 
脚本 "提示 数据 库 连 接 设 置 成 功 。 在 Dreamweaver 编辑 状态 中 的 “数据 库 ” 面板 中 会 出 现 
绑 定 的 RCZP 数据 库 信息 。 

数据 库 连 接 设置 完成 后 , BBS 站 点 内 会 自动 创建 Connections 文件 夹 并 生成 一 个 
RCZP. PHP 程序 文件 。 
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13.5.2 论坛 模块 主页 面 设计 过 程 


论坛 模块 主要 功能 有 发 表 主题 管理 主题 ,该 模块 主页 面 显示 主题 \, 作 者、 内 容 、 发 布 
时 间 及 对 主题 的 回复 。 注 册 用 户 可 以 发 表 主 题 并 对 本 用 户 已 发 表 的 主题 进行 管理 , 当 注 
册 用 户 单 击 每 条 主题 时 会 跳 转 到 相应 主题 的 回复 区 域 进行 评论 ,游客 仅 有 浏览 的 功能 。 

论坛 主页 分 为 三 个 区 域 , 如 图 13-7 所 示 , 即 主题 显示 区 域 .搜索 主题 区 域 ,发 表 主题 
11 管 理 主题 区 。 游 客 登录 到 本 网 站 ,不 会 显示 发 表 主题 1 | 管理 区 内 容 。 在 搜索 区 中 输入 
关键 字 能 够 搜索 出 相关 主题 。 下 面 就 对 每 一 部 分 做 详细 介绍 。 


搜索 主题 

















风 


发 表 主 题 | 管理 














出 | 区 


E 题 显示 区 
图 13-7 信息 论坛 页 面 区 域 划 分 














1. 论坛 模块 主页 面 设计 


(1) 在 编辑 窗口 “设计 "视图 下 打开 Ltindex. PHP 程序 文件 ,选择 菜单 栏 中 的 “插入 "一 
“表格 "创建 第 一 个 1 行 2 列表 格 ,调整 宽度 到 合适 的 位 置 后 ,在 第 一 个 单元 格 设计 “ 搜 
索 ” ,第 二 个 单元 格 中 输入 文字 “发 表 主题 11 管理 "。 

(2) 将 光标 定位 到 表格 的 下 方 ,用 同样 的 方法 再 创建 一 个 3 行 4 列 的 二 维 表格 ,宽度 
对 齐 第 一 个 表格 ,调整 每 个 单元 格 的 大 小 后 ,在 第 一 行 的 四 个 单元 格 中 依次 输入 “主题 ” 
“作者 "内容"“ 发 布 时 间 ”。 第 三 行 合并 一 行 ,并 在 其 中 输入 文字 “目前 没有 发 表 主 题 ” 。 

(3) 由 于 “发 表 主 题 1 | 管理 "功能 选项 对 系统 的 注册 用 户 可 见 , 因 此 需要 对 Session 
[姓名 ' ] 进 行 判断 。 切 换 到 “ 拆 分 "视图 ,并 将 光标 定位 在 代码 窗口 中 “发 表 主 题 1 1 管理 ” 
区 域 , 编 写 如 下 程序 段 : 

<?PHP If (Isset ($ SESSION[' 姓 名 '])){?> 

<A Href ="2jzhuti .PHP" > 发 表 主题 YA>1| 
< 人 A Href ="Ltguanli .PHP" 弟 理 人 A>CQPHP } ?> 

程序 代码 中 使 用 了 Isset( $_SESSION[ ' 姓 名 ' ] ) 判 断 登 录用 户 的 姓名 是 否 存在 ,根据 

PHP 语法 规则 ,需要 在 代码 的 第 一 行 位 置 启动 SESSION ,编写 的 程序 如 下 ， 


<?PHP SESSION Start (); // 启动 会 话 ?> 
2. 论坛 模块 主页 面 绑 定 记 录 集 设计 


(1) 单 击 菜单 栏 中 的 “窗口 "一 “ 绑 定 ”面板 上 的 辆 按钮 ,在 弹出 的 菜单 中 选择 “记录 
集 (查询 ) "命令 ,在 弹出 的 窗口 中 设置 参数 值 ,如 表 134 所 示 。 
表 134 ”设置 记录 集 参数 值 表 
参数 名 称 参数 值 参数 名 称 参数 值 
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名 称 Rsltsy 表格 论坛 
连接 RCZP 列 全 部 














设 署 完成 后 , 单 击 窗口 中 的 “高 级 "按钮 ,进入 图 13-8 所 示 的 编辑 界面 ,将 语句 “Select 
论坛 . 文章 序号 ,论坛 . 文章 主题 ,论坛 .作者 ,论坛 . 内 容 , 论坛 .更 新 时 间 From 论坛 Order 
By 文章 主题 ,文章 序号 "输入 到 *SQL "文本 框 中 , 单 击 右 侧 的 “测试 "按钮 ,经 测试 成 功 后 
单 击 “ 确 定 "按钮 。 


























名 称 : rsltsy 确定 
连接 [Ee | 
二 和 | EE 

帮助 





变量 | 十] 














数据 库 项 -| 本 七 ”表格 
田中 视图 
田 糠 预存 过 程 





























图 13-8 SQL 编辑 界面 


(2) 将 Rsltsy 记录 集 的 字段 插入 到 页 面 第 二 个 表格 相应 的 单元 格 中 , 即 选中 某 个 字 
段 按 住 鼠标 左 键 拖 动 到 相应 单元 格 内 。 


3. 论坛 模块 主页 面 显示 记录 集 的 设计 


(1) 完成 记录 集 的 绑 定 后 ,设置 记录 集 显示 区 域 。 首 先 ,选中 第 二 个 表格 第 二 行 , 即 
已 经 插入 记录 集 要 显示 的 数据 表格 。 单 击 菜单 栏 中 ”窗口 "一 ”服务 器 行 为 "选项 ,在 弹出 
的 窗口 中 单 击 恩 按钮 ,在 弹出 的 菜单 中 选择 * 显示 区 域 " 一 ”如 果 记 录 集 不 为 空 则 显示 ” 选 
项 , 单 击 “ 确 定 ” 按 钮 ,编辑 区 域 左 上 角 出 现 “ 如 果 符合 此 条 件 则 显示 "字样 。 

当 记 录 集 中 没有 发 表 的 文章 数据 时 显示 文字 “目前 没有 发 表 文 章 ” ,采用 同样 的 操作 
模式 ,只 是 将 区 域 设计 成 “如 果 记 录 集 为 空 则 显示 区 域 ”。 

(2) 在 步骤 (1) 设 置 的 显示 区 域 中 , 当 记 录 集 存在 多 条 数据 时 ,为 了 能 够 显示 出 所 有 
符合 条 件 的 数据 ,需要 选择 菜单 栏 中 ”窗口 "一 “服务 器 行为 "的 选项 。 在 打开 的 窗口 中 进 
行 参数 设置 , 即 显示 记录 数 为 5, 单 击 “ 确 定 ”按钮 ,会 在 选取 的 重复 区 域 左 上 和 角 出 现 “ 重 
复 " 的 灰色 标签 。 

(3) 当 显 示 的 记录 集 数据 条 数 超出 5 条 时 ,需要 在 下 一 页 显示 ,这 就 要 求 在 页 面 上 设 
置 记录 集 导航 ,实现 用 户 翻 页 查看 的 功能 。 在 第 二 个 表格 下 方 选 择 菜单 栏 中 的 “插入 "一 
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“数据 对 象 "一 ”~ 记录 集 分 页 "一 “记录 集 导航 条 "选项 。 

在 打开 的 “记录 集 导 航 条 "对 话 框 中 ,选取 记录 集 Rsltsy; 设 置 显示 方式 为 文本" 。 单 
击 “ 确 定 "按钮 回 到 编辑 页 面 。 

4. 论坛 模块 主页 面 中 搜索 区 域 的 程序 设计 

论坛 主页 面 如 图 13-9 所 示 ,利用 表单 创建 搜索 区 域 , 设 置 的 参数 值 如 表 13-5 所 示 。 


搜索 发 表 主题 || 管理 








主题 作者 内 容 发 布 时 间 


皮 宁 软件 公司 运营 专员 | 幸运 安宁 软件 公司 运营 专员 年 莫大 约 多 | 。 2017-03-29 
年 薪 少 ? 12:52:09 








RA 20 万 -30 万 2 

| 要求: 更 ，30 周 罗 以 下 ， 本科 以 上 字 | 2017-03-29 

吉林 大 学 招聘 畏 S 员 | ”如意 。 | 历 。 神 :和 合同 后 次 3000 左 寿 ， | 2011-03.2 
五 了 -全 。 








吉林 大 学 招聘 辅导 员 | 。 顺 发 有 年 终 奖金 吗 ? 3 























图 13-9 信息 论坛 主页 面 


表 13-5 设置 表单 属性 值 表 




















作用 HTML 标签 Name\ID Type 类 型 Value 初始 值 
内 容 <Input / > Key Text 空 

搜索 <Input /> Submit Submit 搜索 
代码 如 下 : 


<Form Method ="POST" Action ="BBS \Ltsearch.PHP" Name ="Search" > 
<Input Type ="Text" Name 一 Key" > 
<Input Name ="Submit" Type =<"Submit" Value = 搜索 "/ ></Form> 
单 击 “ 搜 索 " 按 钮 时 ,执行 Action 属性 设置 的 程序 BBS\Ltsearch. PHP ,根据 Ltsearch. 


PHP 程序 显示 搜索 结果 。 
在 Dreamweaver 中 通过 使 用 记录 和 集 、 服 务 器 行为 的 功能 设计 后 ,会 自动 生成 Ltsearch. 


PHP 的 代码 文件 ,部 分 如 下 所 示 : 
<?PHP SCurrentPage =$ SERVER["PHP_SELE"]; // 引用 当前 网 页 地 址 


SMaxRows Rsltsy 5; // 用 于 分 页 ,每 页 5 行 

SPageNum Rsltsy 30; // 页 码 初 始 化 

If (Isset ($ POST['PageNum Rsltsy'])) // 判断 变量 是 否定 义 过 
SPageNum Rsltsy =$ GET['PageNum Rsltsy']; // 赋值 

SStartRow Rsltsy =SPageNum Rsltsy * SMaxRows Rsltsy; // 起 始 行 

MySQL Select Db ( Spatabase RCZP, $RCZP); // 连接 数据 库 

SKey Strval ( $ POST['Key']); / /获取 关键 字 


SQuery Rsltsy =Select 论坛 .文章 序号 ,论坛 .更 新 时 间 , 论 坛 .文章 主题 ,论坛 .作者 ， 
论坛 .内容 From 论坛 Where 文章 主题 Like '$ Seys ' Or 内 容 Like '%$ $key%' 
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Order By 文章 主题 ,文章 序号 "; // 搜索 文章 主题 或 内 容 中 包含 关键 字 的 文章 
SOuery Limit Rsltsy=Sprintf ("%s Limit $d, sd"，Souery Rsltsy, 
SStartRow Rsltsy，$SMaxRows_Rsltsy); // 格 式 化 的 字符 串 写 入 变量 
SRsltsy =MySQL _ Query ( Query Limit Rsltsy, SRCZP) Or Die (MySQL 











Error ()) 7 
// 发 送 SQL 语句 
SRow Rsltsy -MySQL Fetch Rssoc( $SRsltsy); // 返回 从 结果 集 取得 的 关联 数组 ? > 
在 搜索 区 域 输入 关键 字 , 例 如 * 安 宁 ” ,系统 则 在 RCZP 数据 库 的 论坛 表 中 搜索 文章 主 
题 或 者 内 容 中 带 有 “安宁 "的 相关 记录 并 显示 出 来 ,页 面 显示 结果 如 图 13-10 所 示 。 
主题 作者 内 容 发 布 时 间 
安宁 软件 公司 运营 专员 | 。 幸运 安宁 软件 公司 运营 专员 年 薪 大 约 多 | 。 2017-03-29 
年 薪 少 ? 12:52:09 
客车 志 风 哈哈 笑 20 万 -30 万 2 














图 13-10 ”搜索 显示 页 面 


13.5.3 论坛 模块 发 表 主题 页 面 设计 过 程 


通过 “发 表 主 题 " 链 接 程序 Zjzhuti. PHP 完成 数据 录入 ,程序 的 设计 过 程 如 下 。 
1. 发 表 主题 的 页 面 设计 


(1) 选择 “BBS" 为 当前 站 点 ,从 “文件 "面板 的 “本 地 文件 " 窗 格 里 选中 XXLT 文件 
夹 , 右 击 菜单 中 选择 “新 建文 件 " 选 项 ,文件 命名 为 Zjzhuti. PHP。 选 中 Zizhuti. PHP 并 双 
击 ,该 文件 出 现在 Dreamweaver 编辑 区 域内 。 

(2) 在 编辑 窗口 中 切换 到 “设计 "视图 ,选择 菜单 栏 “ 插 入 "一 “表单 "一 “表单 "选项 ， 
设置 表单 ID 为 Forml \ 方 法 为 POST, 将 光标 定位 到 表单 内 ,选择 菜单 栏 “ 插 入 "一 “表格 ” 
选项 ,设置 表格 为 4 行 2 列 , 设 置 边框 粗细 为 1 ,并 将 第 4 行 合并 单元 格 。 

(3) 调整 单元 格 大 小 后 ,插入 表 13-6 所 示 的 表单 属性 ,由 于 在 标签 属性 的 初始 值 中 用 
到 了 SESSION 对 象 ,所 以 需要 在 该 程序 代码 的 首 行 编 写 ” <? PHP Session_Start( );? >” 
语句 。 


2. 发 表 主 题 的 插入 记录 设计 


(1) 在 Dreamweaver 中 ,可 以 实现 表单 中 输入 的 数据 存储 到 数据 表 中 。 具 体操 作 通 
过 单 击 菜单 栏 的 “插入 ”一 “数据 对 象 " 一 “插入 记录 ”一 “插入 记录 ”选项 实现 。 
表 13-6 设置 表单 属性 值 表 
作用 HTML 标签 Name\ID Type 类 型 Value 初始 值 
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文章 主题 Xin_Biaoti Text 空 
a <? PHP 
Xin_Zuozh T 
发 下 人 | Echo $_SESSION[ 姓名 ];? > 
<Input /> SPH 
Shifi Hidd Date_Default_Timezone_Set 
~ 1an 1 en 
隐藏 域 a ( Asia/ Shanghai’) ; 
Echo Date("Y-m-d" );? > 
MM _Insert Hidden Form 
内 容 <Textarea > | Xin_Neirong 空 
提交 <Input /> Submit Submit 提交 
重 写 <Input /> Submit2 Reset 重 写 














(2) 在 弹出 的 窗口 面板 中 ,各 选项 的 相应 值 设 置 根据 表 13-6 中 提供 的 参数 进行 操 
作 。 保 存 并 运行 程序 ,运行 界面 如 图 13-11 所 示 , 由 于 当前 的 测试 用 户 是 “幸运 ” ,程序 自 
动 读 取 Session 信息 后 ,将 当前 用 户 名 显示 在 作者 栏 内 。 











图 13-11 发表 主 题 界面 


13.5.4 论坛 模块 管理 页 面 设计 过 程 


论坛 模块 的 “管理 "只 针对 系统 的 注册 用 户 ,可 以 针对 发 表 的 主题 进行 修改 和 删除 操 
作 。 当 用 户 单 击 “ 管 理 " 链 接 ,Ltguanli. PHP 程序 会 被 执行 ,该 页 面 会 显示 当前 登录 用 户 所 
发 表 的 所 有 主题 ,具有 “更 改 ”" 和 “删除 ”的 功能 。 具 体 的 设计 流程 如 下 。 


1. 论坛 模块 中 管理 页 面 的 设计 


(1) 选择 “BBS” 为 当前 站 点 ,定位 到 “文件 "面板 的 “本 地 文件 ”中 XXLT 文件 夹 , 右 
击 选择 “新 建文 件 ” ,文件 命名 为 Ltguanli. PHP ,双击 该 文件 出 现在 编辑 区 域 。 

(2) 在 “设计 "视图 下 ,选择 菜单 栏 中 的 “插入 "一 “表格 "创建 一 个 3 行 6 列 ,边框 粗 
细 值 为 1 的 二 维 表格 ,调整 宽度 到 合适 的 位 置 后 ,在 第 1 行 从 左 至 右 的 单元 格 中 依次 输 
入 :“ 主 题 “ 作 者 “内 容 “ 发 布 时 间 ”“ 更 改 “ 删 除 "” 。 选 中 表格 第 3 行 后 右 击 , 弹 出 菜 
单 , 选 择 * 表 格 " 一 “合并 单元 格 (M) "选项 ,并 输入 * 目前 没有 发 表 文章 ”, 调 整 每 个 单元 
格 的 大 小 并 适应 文字 内 容 。 
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2. 论坛 模块 中 管理 页 面 的 绑 定 记 录 集 设计 


(1) 单 击 菜单 栏 中 的 “窗口 ”一 ”“ 绑 定 "面板 上 的 国 按钮 ,在 弹出 的 菜单 中 选择 “记录 
集 ( 查 询 ) "选项 ,在 弹出 的 窗口 中 设置 参数 值 ,如 表 13-7 所 示 。 


表 13-7 设置 记录 集 参 数值 表 








参数 名 称 参数 值 参数 名 称 参数 值 
名 称 Rsltgl 表格 论坛 
连接 RCZP 列 全 部 











设置 完成 后 , 单 击 窗口 中 的 “高 级 …" 按 钮 ,进入 到 SQL 的 语法 编辑 界面 ,并 输入 如 下 
SQL 代码 : 

Select 论坛 .文章 序号 ,论坛 .文章 主题 ,论坛 .作者 ,论坛 .内 容 ,论坛 .更 新 时 间 From 论坛 where 

论坛 .作者 ='". $ SESSION[' 姓 名 '] ."' Order By 文章 主题 ,文章 序号 ; 

单 击 窗口 中 的 “确定 "按钮 完成 操作 。 

(2) 将 Rsltgl 记录 集 的 字段 插入 到 表格 第 2 行 相 应 的 单元 格 中 , 即 选中 某 个 记录 集 
字段 ,并 按 住 鼠 标 左 键 拖 动 到 相应 单元 格 内 。 在 对 应 “更 改 " 列 的 单元 格 内 输入 文字 “ 操 
作 ” ,选中 输入 的 文字 后 ,在 属性 面板 中 的 “链接 " 栏 , 编 写 链接 代码 : 


Xgzhuti .PHP?WZBH =<?PHP Echo SRow Rsltgl [' 文 章 序号 ']; ?> 


在 对 应 “删除 " 列 的 单元 格 内 输入 文字 ”执行 ”, 选 中 输入 的 文字 后 ,在 属性 面板 中 的 
“链接 " 栏 ,编写 链接 代码 ,完成 记录 集 Rsltgl 的 绑 定 ; 


Sczhuti .PHP?WZBH =<?PHP Echo SRow Rsltgl [' 文 章 序号 '"]; ?> 


3. 论坛 模块 中 管理 页 面 的 显示 记录 集 设 计 


(1) 选取 表格 第 二 行 , 即 已 经 插入 记录 集 要 显示 数据 的 表格 。 

(2) 单 击 菜单 栏 中 "窗口 "一 ”服务 器 行为 "选项 ,在 弹出 的 窗口 中 选择 转 按 钮 ,在 弹 
出 的 菜单 中 选择 * 显示 区 域 " 一 ”如果 记 录 集 不 为 空 则 显示 区 域 " 选 项 。 

(3) 单 击 “确定 "按钮 ,编辑 区 域 左 上 角 出 现 “ 如 果 符 合 此 条 件 则 显示 ”。 

(4) 当 记 录 集 中 没有 数据 时 显示 文字 “目前 没有 回复 主题 1” ,采用 步 又 (2) 的 操作 模 
式 , 只 是 将 区 域 设计 成 “如 果 记 录 集 为 空 则 显示 ” 即 可 。 

(5) 在 设置 的 显示 区 域 中 , 当 记 录 集 存在 多 条 数据 时 ,为 了 能 够 显示 出 所 有 符合 条 件 
的 数据 , 则 需要 选择 菜单 栏 中 “窗口 "一 “服务 器 行为 "的 选项 ,在 打开 的 窗口 中 进行 参数 
设置 , 即 显示 记录 数 为 5, 单 击 “确定 ”按钮 ,会 在 选取 的 重复 区 域 左 上 角 出 现 “ 重 复 " 的 灰 
色 标 签 。 

(6) 当 显示 的 记录 集 数据 条 数 超出 5 条 , 则 需要 在 下 一 页 显示 ,这 就 要 求 在 页 面 上 设 
站 记录 和 集 导航 ,实现 用 户 翻 页 查看 的 功能 。 在 第 二 个 表格 下 方 选 择 菜单 栏 中 的 “插入 ”一 
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“数据 对 象 "一 ”~ 记录 集 分 页 "一 ”记录 集 导航 条 "选项 。 
在 打开 的 “记录 集 导 航 条 ”对话 框 中 ,选取 记录 集 为 Rsltsy, 设 置 显示 方式 为 文本 。 单 
击 * 确 定 "按钮 回 到 编辑 页 面 ,完成 显示 记录 集 的 设计 。 


4. 论坛 管理 模块 中 管理 页 面 的 程序 设计 


管理 页 面 中 用 到 了 Session 对 象 ,需要 在 代码 的 首 行 输入 “ < ?PHP Session_Start( ); ?>” 
语句 ,保存 以 上 所 有 操作 后 在 浏览 器 中 打开 程序 ,并 以 注册 用 户 登 录 系统 进行 测试 ,程序 运行 
的 效果 如 图 13-12 所 示 。 








一 一 | _ 主题 | 作者 | 内 容 | 发布 时 间 | 更 次 | 际 |] 
ES 
图 13-12 主题 管理 界面 
(1) 在 程序 运行 中 , 当 单 击 更 改 列 的 “操作 ”链接 到 Xgzhuti. PHP 文件 ,程序 运行 的 界 





面 如 图 13-13 所 示 。 





请 修改 主题 和 内 容 ; 
主题 : 








支 宁 软 件 公司 运营 专员 年 吉大 约 多 少 人 


内 容 : 











| 从 次 | 
图 13-13 ”主题 修改 界面 


在 Dreamweaver 中 通过 使 用 记录 集 .服务 器 行为 等 功能 设计 后 ,会 自动 生成 更 改 操作 
的 数据 处 理 程序 ,部 分 代码 片段 如 下 所 示 : 


SUpdatesQL =Sprintf ("Update 论坛 Set 内 容 攻 S, 文章 主题 成 S Where 文章 序号 阁 S, 
GetSQLValueString ($S POST['Neirong'], "Text"), 
GetSQLValueString( $ POST['Biaoti'], "Text"), 
GetsQLValueString( $ POST['WZBH'], “Int")); 
// ”根据 文章 序号 更 新 文章 内 容 .主题 
Mysql_Select Db( SDatabase RCZP, $RCZP); // 连接 数据 库 
SResult1 -MySQL Query(SUpdateSQL，SRCZP) Or Die MySQL Error()); // 执行 更 新 操作 


(2) 在 程序 运行 中 , 当 单 击 删 除 列 中 “执行 "链接 ,执行 Sczhuti. PHP 文件 ,进行 记录 
的 删除 操作 ,其 数据 处 理 程序 如 下 : 
SDeleteSQL =Sprintf ("Delete From ` 论 坛 、 Where 文章 序号 坊 S"， 


GetSQLValueString($ GET["WZBH']，"Int")) 7 // 根据 文章 序号 删除 文章 
MySQL _ Select Db ( $Database RCZP, $RCZP); // 连接 数据 库 
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SResultl -MySQL Query ( SDeleteSQL，SRCZP) Or Die (MySQL Error()); // 删 除 记录 操作 


13.5.5 论坛 模块 中 回复 主题 页 面 的 设计 过 程 


系统 的 注册 用 户 有 回复 主题 的 权限 , 当 用 户 登录 系统 浏览 相应 的 主题 时 ,可 以 进行 主 
题 内 容 的 回复 。 


1. 回复 主题 的 页 面 设计 


(1) 在 编辑 窗口 “设计 ”视图 下 打开 Ltindex. PHP 程序 文件 ,选择 菜单 栏 “ 插 入 ”一 “ 表 
单一 “表单 "选项 ,设置 表单 Name 为 Form ,方法 为 POST 后 ,将 光标 定位 到 表单 内 ,选择 菜 
单 栏 “插入 "一 “表格 "选项 ,设置 表格 为 4 行 2 列 . 边 框 粗细 为 1, 并 将 第 4 行 合并 单元 格 。 

(2) 调整 单元 格 大 小 后 ,按照 表 13-8 所 示 的 数据 ,进行 表单 属性 参数 设置 。 


表 13-8 设置 表单 属性 值 表 























作用 标签 Name\ID Type 类 型 Value 初始 值 
回复 主题 Xin_Biaoti Text 空 
<? PHP 
二 ? 
回复 人 Xin_Zuozhe Text Echo $_SESSION[ 姓名 ];? > 
<Input /> 区 
Shifi Hidd Date_Default_Timezone_Set 
隐藏 域 ( Asia/Shanghai’) ; 
Echo Date("Y-m-d" ) ; ? > 
MM _Insert Hidden Form 
内 容 <Textarea > | Xin_Neirong 空 
回复 <Input /> | Submit Submit 回复 
重 写 <Input /> | Submit2 Reset 重 写 














(3) 运行 程序 , 单 击 “ 回 复 " 链 接 , 会 出 现 如 图 13-14 所 示 的 界面 。“ 回复 人 ” 栏 默 认 


值 是 程序 读 取 SESSION 值 ,自动 获得 当前 的 用 户 名 。 


回复 主题: 


(4) 表单 部 分 的 代码 片段 如 下 : 





| 


Ei 


回复 人 : 库 运 





内 容 : 











图 13-14 ”主题 回复 界面 


<Eorm Method ="POST" Action =" <?PHP Echo S$EditFomAction; ? >" Name ~"Form" ><Table > 


<Tr ><Td Width "12%$" ><Div Align ~"Right" > 回复 文章 : </Div> 


<Tq Width ="88%$" ><Input Name ="Xin Biaoti" Type ="Text" Size="40" /><TF> 
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<Tr><Td><Div Align ="Right" > 回复 人 : </Div> 
<Td ><Input Name ~"Xin Zuozhe" Type =Text" Value = <?PHP Echo $ SESSION[ "姓名 
'];? >" Size 2"20" Maxlength ="10" Readonly ="Readonly" / ></Tr > 
<Tr ><Td Valign ="Top" ><Div Align "Right" >: 肉 容 : Div> 
<Td ><Textarea Name =Xin Neirong" Cols ="35" Rows 2"1" ></Textarea ></Tr > 
<Tr ><Td Colspan ="2" ><Input Name 一 Submit" Type ="Submit" Value 一 "回复 " /> 
<Input Type "Reset" Name ="Submit2" Value 一 重 写 " / ></Tr ></Table > 
<Input Type ="Hidden" Name =“"MM Insert" Value 一 Form" ></Form> 


2. 回复 主题 的 设计 


在 Dreamweaver 中 通过 记录 集 .服务 器 行为 等 功能 设计 回复 主题 页 面 的 数据 处 理 后 ， 
会 自动 生成 程序 代码 片段 如 下 : 


$InsertSQL =Sprintf ("Insert Into “论坛 ”( 作 者 , 内 容 ， 文章 主题 ) Values (%S, gsS, %S)", 
GetSQLValueString($ POST["Xin Zuozhe'], "Text"), 
GetSQLValueString( $ POST["Xin Neirong'], "Text"), 
GetSQLValueString($ POST["Xin Biaoti'], "Text") ); 
MySQL Select_Db ( $Database RCZP, $RCZP); // 连接 数据 库 
Resultl -MySQL Query ( SInsertSQL， SRCZP) Or Die (MySQL Error()); // 插 入 记录 操作 


13.6 网 站 发 布 


将 开发 完成 的 人 才 招 聘 BBS 发 布 到 互联 网 的 方法 有 很 多 种 ,最 常用 的 方式 是 使 用 独 
立 IP 的 服务 器 或 租用 云 主 机 。 但 不 论 使 用 哪 种 方式 ,都 需要 有 属于 自己 的 域名 ,使 用 户 
在 互联 网 上 能 够 更 容易 地 访问 到 。 


13.6.1 通过 独立 IP 的 服务 器 发 布 项 目 


系统 的 发 布 只 需要 在 具有 独立 IP 的 服务 器 上 安装 PHP 运行 环境 并 将 申请 的 域名 解 
析 到 服务 器 即 可 ,配置 的 过 程 是 通过 更 改 Apache Web 服务 器 的 httpd. conf 文件 中 Virtual 
Hosts 模块 的 参数 值 完 成 ,其 具体 代码 部 分 如 下 : 


<VirtualHost:80 > 
DocumentRoot 代码 保存 在 服务 器 上 绝对 路 径 值 
ServerName ”对 应 的 网 站 域名 ”</VirtualHost > 


修改 完成 后 将 项 目 文件 的 内 容 , 分 别 复制 到 指定 的 目录 中 后 重新 启动 Apache Web 服 
务 器 即 可 生效 。 


13.6.2 通过 租用 云 主机 发 布 项 目 
使 用 租用 虚拟 云 主机 空间 的 方式 发 布 站 点 ,需要 经 过 域名 申请 ,购买 主机 解析 域名 、 
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备案 和 上 传代 码 四 个 步骤 ,本 章 主要 以 阿里 云 为 案例 进行 流程 上 的 介绍 。 
1. 域名 申请 


根据 系统 的 特点 ,设计 好 域名 后 进行 申请 注册 。 首 先 ,准备 申请 资料 COM 域名 无 须 
提供 身份 证 .营业 执照 等 资料 ,CN 域名 已 开放 个 人 申请 注册 ,所 以 申请 只 需要 提供 身份 
证 或 企业 营业 执照 。 其 次 ,寻找 域名 注册 网 站 ,由 于 . COM、. CN 域名 等 不 同 后 级 均 属于 
不 同 注册 管理 机 构 所 管理 ,如 要 注册 不 同 后 级 域名 则 需要 从 注册 管理 机 构 寻 找 经 过 其 授 
权 的 顶级 域名 注册 服务 机 构 。 如 COM 域名 的 管理 机 构 为 ICANN (国际 域名 管理 中 心 ) ， 
CN 域名 的 管理 机 构 为 CNNIC( 中 国 互 联网 络 信息 中 心 ) 。 域 名 注册 是 Internet 中 用 于 解 
决 地址 对 应 问题 的 一 种 方法 。 

域名 注册 遵循 先 申请 先 注册 原则 ,管理 机 构 对 申请 人 提出 的 域名 是 否 违 反 了 第 三 方 
的 权利 不 进行 任何 实质 审查 。 每 个 域名 都 是 独一无二 的 ,不 可 重复 的 。 因 此 ,在 网 络 上 ， 
域名 是 一 种 相对 有 限 的 资源 。 命 名 规则 如 下 : 

(1) 可 以 包含 英文 字母 (a-z, 不 区 分 大 小 写 ) 数字 (0-9) ,以 及 半角 的 连接 符 *-”( 即 
中 横 线 ) ,不 能 使 用 空格 及 特殊 字符 ( 如! 、$、&、? 等 )。 

(2)“-" 不 能 连续 出 现 , 不 能 单独 注册 ,也 不 能 放 在 开头 或 结尾 。 


2. 购买 云 主机 


购买 云 主机 ,可 根据 自己 的 需求 来 选择 购买 哪 种 云 主机 ,在 阿里 云 网 站 的 产品 列表 上 
都 有 详细 的 说 明 。 需 要 注意 在 选择 主机 类 型 时 ,确定 是 Windows 或 者 Linux 系统 ,因为 支 
持 的 编程 语言 和 数据 库 不 同 。 


3. 将 域名 解析 到 服务 器 


域名 和 云 主机 购买 成 功 后 ,接着 将 域名 地 址 指向 虚拟 服务 器 的 下。 在 主机 信息 中 查 
看 到 IP 地 址 ,然后 进行 域名 解析 ,将 已 经 成 功 申请 到 的 域名 解析 到 购买 的 主机 IP 地 址 
上 ,并 进行 备案 操作 。 


4. 备案 和 上 传 系统 代码 


根据 阿里 云 上 提供 的 网 站 备案 流程 进行 相应 的 操作 ,信息 提交 完成 后 等 待 审核 。 通 
过 后 ,会 发 送 邮 件 到 注册 邮箱 中 ,上 传 系统 的 构建 代码 到 云 主机 服务 器 上 ,搭建 和 配置 好 
环境 后 ,就 能 正式 访问 了 。 


13.7 网 站 的 运营 与 推广 


网 站 运营 与 推广 是 网 站 能 否 持续 成 长 的 关键 ,这 是 一 项 长 期 且 不 能 间断 的 工作 。 
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13.7.1 网 站 运营 的 内 容 与 方法 


网 站 运营 是 指 为 了 提升 网 站 服务 于 用 户 的 效率 ,而 从 事 与 网 站 后 期 运作 .经营 有 关 的 
工作 。 范 畴 通常 包括 网 站 内 容 更 新 维护 、 网 站 流程 优化 .数据 挖掘 分 析 用 户 研究 管理 网 
站 营销 策划 等 。 网 站 运营 是 一 个 总 体 概念 ,包括 了 设计 编程 .客户 服务 公司 管理 等 。 


1. 运营 内 容 


网 站 运营 是 网 站 推广 营销 里 的 一 个 重要 名 词 , 从 两 个 层面 来 理解 : 

从 大 的 方面 来 看 ,网 站 运营 是 一 切 与 网 站 活动 相关 的 总 称 ,甚至 包括 技术 、 美 工 市 
场 ,销售 内容 建 设 等 , 皆 属 于 网 站 运营 的 范畴 。 

从 小 的 方面 来 看 ,网 站 运营 却 是 独立 于 技术 美工 .销售 ,市场 等 工作 内 容 而 存在 的 ， 
在 一 些 大 的 网 络 公司 ,一 般 都 设 有 专门 的 网 站 运营 部 门 。 对 网 站 运营 的 理解 ,我 们 还 是 应 
当 从 小 的 方面 切入 ,才能 具体 的 对 网 站 运营 进行 定义 ,更 明确 网 站 运营 的 具体 内 容 。 

(1) 需求 分 析 和 整理 : 对 于 一 名 网 站 运营 人 员 来 说 ,最 为 重要 的 就 是 要 了 解 需求 ,在 
此 基础 上 ,提出 网 站 具体 的 改善 建议 和 方案 ,并 确认 这 些 建议 和 方案 是 否 具体 可 行 。 需 求 
创新 直接 决定 了 网 站 的 特色 ,有 特色 的 网 站 才 会 更 有 价值 , 才 会 更 吸引 用 户 来 使 用 。 网 站 
推广 细节 的 改变 ,应 当 是 基于 对 用 户 需 求 而 产生 的 。 

(2) 频道 内 容 建设 : 是 网 站 推广 运营 的 重要 工作 。 网 站 内 容 , 决 定 了 网 站 的 发 展 方 
向 。 频 道内 容 建设 ,更 多 的 工作 是 由 专门 的 编辑 人 员 来 完成 ,内 容 包括 频 道 栏目 规划 、 信 
息 编辑 和 上 传 信 息 内 容 的 质量 提升 等 。 网 站 内 容 质量 的 提升 ,应 当 是 编辑 人 员 最 终 的 追 
求 目标 。 很 多 的 小 网 站 ,网 站 编辑 人 员 就 承担 着 网 站 推广 运营 人 员 的 角色 ,不仅 要 负责 信 
息 的 编辑 ,还 要 提 需 求 .做 方案 等 。 

(3) 网 站 策划 : 包括 前 期 市 场 调研 .可行 性 分 析 、 策 划 文档 撰写 .业务 流程 说 明 等 内 
容 。 策 划 是 建设 网 站 的 关键 ,因为 ,前 期 的 网 站 策划 涉及 更 多 的 市 场 因素 。 

(4) 产品 维护 和 改进 工作 : 其 实 与 前 面 讲 的 需求 整理 分 析 有 一 些 相似 之 处 。 产 品 维 
护 工作 ,更 多 应 是 对 顾客 已 购买 产品 的 维护 工作 ,响应 顾客 提出 的 问题 。 此 外 ,产品 维护 
还 包括 制定 和 改变 产品 政策 .进行 良好 的 产品 包装 .改进 产品 的 使 用 体验 等 。 

(5) 各 部 门 协调 工作 : 这 一 部 分 的 工作 内 容 , 更 多 体现 的 是 管理 角色 。 运 营 人 员 因 
为 深 知 整个 网 站 推广 的 运营 情况 ,知识 面相 对 来 说 比较 全 面 ,与 技术 人 员 美工 .测试 . 业 
务 的 沟通 协调 工作 ,更 多 地 是 由 运营 人 员 来 承担 。 优 秀 的 网 站 运营 人 才 , 要 求 具备 行业 专 
业 知识 ,文字 撰写 能 力 .方案 策划 能 力 ,沟通 协调 能 力 .项 目 管理 能 力 等 方面 的 素质 。 毫 无 
疑义 ,网 站 只 有 拥有 了 优秀 的 运营 人 才 , 网 站 才 会 运营 得 更 加 成 功 。 

综 上 所 述 ,网 站 推广 运营 是 一 件 非常 重要 的 事情 ,只 有 优秀 的 运营 人 才 来 指导 整个 网 
站 工作 ,才能 得 到 更 好 的 运营 效果 ,也 才能 成 为 一 个 成 功 的 网 站 。 


2. 运营 方法 
网 站 运营 需要 根据 运营 的 实际 情况 建立 一 套 良好 的 体系 ,系统 规范 地 规划 网 站 运营 
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的 各 个 方面 。 从 具体 业务 角度 出 发 ,网 站 运营 主要 包括 以 下 三 个 具体 方面 : 
(1) 对 网 站 的 现状 进行 把 脉 ,监控 开发 使 用 的 整体 情况 。 
(2) 根据 网 站 整体 战略 ,制定 阶段 性 目标 。 
(3) 根据 网 站 的 目标 和 即时 动态 情况 ,制定 并 实施 相关 运营 措施 。 


13.7.2 网 站 推广 的 意义 与 方法 


网 站 推广 就 是 以 国际 互联 网 为 基础 ,利用 信息 和 网 络 媒体 的 交互 性 来 辅助 营销 目标 
实现 的 一 种 新 型 的 市 场 营 销 方式 。 简 单 地 说 ,就 是 以 互联 网 为 主要 手段 进行 的 ,为 达到 一 
定 营 销 目的 的 推广 活动 。 


1. 网 站 推广 的 意义 


网 站 推广 是 企业 网 络 营 销 的 核心 内 容 , 应 该 给 企业 提供 的 是 能 创造 效益 的 网 站 ,而 不 
是 作为 摆设 的 网 站 ,因此 ,网 站 推广 是 企业 网 络 营销 成 败 的 关键 所 在 。 一 个 真正 可 执行 的 
网 络 推广 方案 应 该 具备 以 下 因素 : 在 写 方案 之 前 一 定 要 先 理 顺 思路 ,要 注重 方案 的 可 操 
作 性 实用 性 ,不 需要 炫耀 文 薄 ,只 需要 将 意思 表达 明白 就 行 ,要 注意 基本 格式 和 版 面 布局 
技巧 ,避免 基本 的 文字 和 排版 错误 等 ,要 方便 阅读 。 


2. 推广 方法 


(1) SEM 推广 : SEM 是 Search Engine Marketing 的 缩写 ,中 文 意思 是 搜索 引擎 营销 。 
SEM 追求 最 高 的 性 价 比 ,以 最 小 的 投入 获得 最 大 的 来 自 搜索 引擎 的 访问 量 并 产生 商业 
价值 。 

(2) SEO 推广 : SEO 的 Search Engine Optimization 的 缩写 ,中 文 译 为 搜索 引擎 优化 。 
它 的 主要 原理 是 通过 抬 高 目标 网 站 在 搜索 引擎 中 的 排名 来 达到 推广 目的 。 

(3) SNS 推广 : SNS 是 Social Network Software 的 缩写 ,中文 译 为 社会 性 网 络 软件 ,是 
利用 网 络 社交 软件 或 应 用 其 功能 进行 宣传 推广 ,从 而 达到 提升 品牌 知名 度 ,促进 产品 销售 
等 目的 的 活动 , 即 称 为 SNS 推广 。 

(4) SMM 推广 : SMM 的 全 称 是 Social Media Marketing ,中 文 意思 是 社会 化 媒体 营销 ， 
是 利用 社会 化 网 络 .在线 社区 ,博客 百科、 图 片 和 视频 分 享 等 ,进行 推广 营销 信息 平台 。 








习 题 


一 、 填 空 题 
1. 根据 ”对象 所 保存 的 用 户 身份 信息 ,可 以 判断 出 用 户 是 系统 的 注册 用 户 。 


2. 是 整个 人 才 招 聘 BBS 系统 的 核心 网 页 ,引领 用 户 浏览 其 他 内 容 的 交互 界面 。 
3. 人 才 招 聘 BBS 系统 在 主页 交互 界面 设计 上 采用 简洁 的 设计 风格 ,主要 采用 HTML 
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的 ”技术 。 

4. 是 网 页 中 引导 用 户 访问 网 站 中 的 菜单 .栏目 等 内 容 及 页 面 之 间 互 相 链 接 的 布 
局 结构 的 统称 。 

5. 人 才 招 聘 BBS 系统 采用 了 _ 模式 。 

6. 在 Dreamweaver 开发 环境 中 ,在 数据 库 面板 区 域 为 站 点 设置 数据 连接 自动 产 





生 文件 夹 。 
7. 因特网 上 一 个 服务 器 或 一 个 网 络 系统 的 名 字 称 为 。 _, 网 络 间 正 是 通过 它 进 行 相 
互 访问 的 。 


8. 网 页 超级 链接 是 一 种 “的 关系 。 
9. Method 属性 有 两 种 方法 QD 和 @ 。 
10. 域名 中 只 能 包含 @ 、@ 和 @ 字符 。 








二 、 单 选 题 
1. 本 章 中 所 设计 的 人 才 招 聘 BBS 系统 所 采用 的 数据 库 平 台 是 ( )。 

A. MySQL B. Oracle C. Access D. SQL Server 
2. 人 才 招 聘 BBS 中 对 MySQL 进行 配置 是 在 ( ) 图形 化 环境 中 进行 的 。 

A. PHPMyAdmin B. index. php C. php. dwt D. php. php 
3. PHP 采用 通过 ( ) 对 象 保存 用 户 的 身份 信息 ,为 系统 中 的 用 户 分 配 权限 。 

A. Session B. Cookie C. Connection D. Form 
4. 人 才 招 聘 BBS 系统 的 首页 文件 名 称 是 ( ”)。 

A. Index. html B. Index. php C. Index. htm D. Index 
5. 人 才 招 聘 BSS 使 用 ( ) 请 求 ,数据 是 后 级 在 URL 后 面 进行 传递 的 。 

A. POST B. GET €. PUT D. FORM 
6. PHP 将 GET 请 求 封装 在 ( 。 ”) 数 组 中 ,请 求 的 变量 名 是 数组 的 下 标 。 

A. $_POST B. GET C. $_GET D. $_FORM 
7. 在 PHP 中 ,POST 方 法 的 请 求 数据 被 封装 到 ( 。 ”) 数 组 中 。 

A. $_POST B. GET C. $_GET D. $_FORM 
8. 在 PHP 中 释放 结果 内 存 的 函数 是 (。” )。 

A. MySQL_Free_result( ) B. MySQL_Result( ) 

C. Free_Result( ) D. MySQL _Free ( ) 


9. 将 申请 的 域名 解析 到 服务 器 ,可 以 通过 配置 Apache 服务 器 的 ( ) 文件 中 
Virtual Hosts 模块 。 


A. httpd. conf B. php. Int C. http. hph D. httpd. ini 
10. 人 才 招 聘 BBS 系统 中 ,客户 端 向 服务 器 端 发 送 的 数据 称 之 为 (”_Q@ _) ,反之 称 
为 (_ 加 )。 


A. 请 求 ,响应 B. 响应 ,请 求 C. 调用 ,响应 D. 请 求 ,发 送 
11. 在 Dreamweaver 开发 环境 中 ,在 数据 库 面 板 区 域 为 站 点 设置 数据 连接 自动 产生 
( 文件 夹 。 
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A. Connections B. Mysql C. Result Db; PHP 
1 ) 推 广 以 最 低 的 投入 .最短 的 时 间 、 最 多 平台 获得 来 自 搜索 引擎 的 访问 量 ， 


从 而 产生 商业 价值 。 
A. SEM B. SEO CG: SNS D. SMM 
13.( ”) 推 广 是 通过 抬 高 目标 网 站 在 搜索 引擎 的 排名 来 达到 推广 的 目的 。 
A. SEM B. SEO C. SNS D. SMM 


14. ( ) 推 广 通过 论坛 推广 微 博 推广 、 微 信 推 广 等 网 络 社交 软件 进行 宣传 推广 ， 
从 而 达到 提升 品牌 知名 度 ,促进 产品 销售 等 目的 。 
A. SEM B. SEO C. SNS D. SMM 
15 六 ) 推 广 利用 社会 化 网 络 \ 在 线 社区 、 百 科 、 图 片 和 视频 分 享 等 ,利用 高 人 气 的 
平台 进行 营销 信息 推广 。 
A. SEM B. SEO C. SNS D. SMM 
三 、 多 选 题 
1. 关于 表单 的 Method 属性 ,叙述 正确 的 是 ( ¥s 
.Method 属性 有 两 种 方法 GET 和 POST 
B. GET 方法 发 送 的 数据 跟随 在 URL 后 面 
C. 两 种 方法 允许 发 送 数据 到 服务 器 端 
D. POST 方法 发 送 的 数据 跟随 在 URL 后 面 
E 
F 


= 


. GET 方法 和 POST 方法 在 发 送 数据 方式 上 相同 
.GET 方法 和 POST 方法 发 送 数据 到 客户 端 
2. PHP 主要 是 通过 Session 函数 来 对 Session 进行 控制 和 使 用 ,使 用 Session 时 需要 注 
意 ( ) 。 
A. 将 Session_Start( ) 函数 写 在 第 一 行 
B. 使 用 Session 之 前 ,一 定 要 先 写 Session_Start( ) 函数 
C. Session_Start( ) 函数 写 在 最 后 一 行 
D. 使 用 Session 之 后 ,可 以 直接 调用 Session_Start( ) 函数 
E. Session 没有 时 限 约束 
F. Session_Start( ) 函数 可 以 设置 Session 时 效 
3. 下 列 关于 Session 叙述 中 ( ) 正确 。 
A. Session 存储 在 服务 器 端 
B. Session 的 时 效 是 用 户 从 进入 网 站 开始 直到 关闭 退出 网 站 
C. PHP 中 对 Session 进行 配置 是 在 php. ini 文件 中 进行 的 
D. Session 的 中 文 译 为 “会 话 ” 
.Session 存储 在 客户 端 
F. PHP 中 对 Session 进行 配置 是 在 config. ini 文件 中 进行 的 
4. 下 列 关 于 人 才 招 聘 BBS 的 叙述 中 ( ) 正确 。 
A. BBS 也 译 为 电子 公告 板 
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B. 人 才 招 聘 BBS 是 集 招 聘 信息 和 论坛 两 部 分 功能 的 系统 
C. 人 才 招 聘 BBS 系统 的 运行 模式 是 B/S 结构 
D. 人 才 招 聘 BBS 系统 的 开发 使 用 的 是 PHP 语言 
E. 人 才 招 聘 BBS 系统 的 运行 模式 是 C/S 结构 
F. 人 才 招 聘 BBS 系统 的 数据 库 采 用 MySQL 
5. 下 列 关 于 人 才 招 聘 BBS 在 Dreamweaver 中 创建 站 点 的 叙述 中 正确 的 是 ( 炳 
A. 站 点 的 名 称 是 RCZP 
B. 连接 的 方法 是 本 地 /网 络 
C. Web URL 是 Http://LocalHost/RCZP 
D 
E 
F 








.服务 器 模型 是 PHP MySQL 
. 站 点 创建 完成 后 可 以 进行 管理 和 编辑 
. 站 点 里 保存 着 人 才 招聘 BBS 系统 的 所 有 文件 
6. 以 下 属于 网 站 运营 的 内 容 是 ( 短 
A. 网 站 内 容 更 新 维护 B. 网 站 流程 优化 
C. 数据 挖掘 分 析 D. 用 户 研 究 管理 
E. 网 站 营销 策划 
7. 导航 遵循 以 下 原则 ( )5 
A. 组 织 良好 的 链接 B. 导航 清晰 鲜明 ”C. 导航 不 一 致 


D. 色彩 鲜明 E. 易于 理解 

8. 网 站 打开 速度 取决 于 以 下 因素 ( ) 。 
A. 网 页 内 容 B. 网 络 带宽 C. DNS 解析 时 所 花费 的 时 间 
D. 域名 E. 服务 器 和 客户 端 机 器 的 配置 


9. 下 列 域名 格式 中 ,错误 的 是 ( ”)。 


A. www. 1986. com B. www@ com. cn CC. www.edu_ruyi. com 


D. www. ruyi. net E. www.abc?.com F. www.c++.gov 

10. 网 站 推广 的 方法 有 ( ” ) 。 
A. SEM B. SEO C. SNS D. SMM 
E. SCE F. CNN 


四 、 程序 填空 题 
1. 利用 HTML 表单 技术 设计 登录 界面 。 


<Eorm Name "Fom" QD "Post" @ "Process/Dlchuli.PHP"> 
< 忆 兹 号 : <Input Type ="Text" Name ="Account"/></P> 
也 北 码 : <Input Type ="'Password" Name 2"'Pw" / ></P> 

<Input Type 一 Submit" Name "D1" Value =" 登录"/ > 
志和 图 > 


2. 编写 连接 MySQl 数据 库 的 程序 。 


第 13 章 ， BBS 系统 的 程序 设计 


(57 


<?PHP 
_@ -New MysQL('IocalHost' 'ywy@ LocalHost', 'ywy211',' 加 '); 
// 连 接 RCZP 数据 库 , 用 户 是 ywy@ LocalHost, 密 码 为 ywy211 
图 (MysQL,"set Names 'UTE8'"); ?> 


3. 利用 表单 技术 编写 注册 页 面 。 


< 上 orm -A ="Form" Method ="Post" Action =". ./Process/Zhcchuli .PHP" > 
<! -Action 指定 后 台 处 理 程序 是 站 点 Process 文件 夹 下 的 Zhcchuli .PHP 文 件 --> 
< 也 淘 份 证 号 : <Input Type "Text" Name ="'Id"/ ></P> 
< 浴 名 : <Input Type ="Text" Name ="Name"/ ></P> 
也 帝 码 : <Input Type ="Password" Name "Pw" / ></P> 
PP><nput Type = 四 "Name <"Dl" @ = 注册 "/ ></P> 


</EForm > 
4. 设计 一 个 注册 处 理 程序 。 
<?PHP 
@D ("connDB.PHP"); // 连接 数据 库 
$Id=$ POST['Id']; // 身份 证 号 值 赋 给 Ia 
SName =$ POST['Name']; // 姓名 值 赋 给 Name 
S$Pw =$ POST['Pw']; // 密码 值 赋 给 Pw 


@) ="Insert Into YPRYB (身份 证 号 ,姓名 ,密码 )Value(' $Id', ' SName', ' SPw') "7 
// 将 值 插入 到 数据 表 YPRYB 
图 “aySQL Query(SMySQL, SSQL) 7 // 发 送 SQL 语句 ?> 


5. 利用 框架 集 设 计 具 有 大 小 固定 的 上 方 框架 和 内 套 的 左 侧 框架 的 框架 页 。 


<Erameset D "200,*#"Cols—*"> 
<Erame Src ="Top.PHP" Name ="Top" Scrolling 2"No"/ > 
<Erameset Rows 二 + @ ="100,*" > 
<ETrame Src ="Left .HIML" Name ="Left" Scrolling ="No" Noresize /> 
<Frame Src ="Jieshao .HIML" Name ="Main" Scrolling ="Yes" Noresize / > 
® 


</Frameset > 
6. 如 下 代码 实现 对 GWB 表 数 据 集 的 查询 。 


<2PHP 
Header ("Content -Type: Text/HIML; Charset =UTF -8"); 
Function ShowContent () 
{ Require ("ConnDB.PHP"); // 引入 connpB.PHP 创建 数据 库 连接 
SSQL ="Select * From GWB ”QD 笔试 日 期 Desc"; 
// 选择 数据 表 GWB 的 所 有 字段 按 笔 试 日 期 降序 排列 
SCount 0; // 用 于 计算 招聘 记录 的 数量 
Snrr =array () 7 // 存放 记录 信息 的 数组 
IfE(SResult = @ (SSQD)) ”// 执行 查找 操作 得 到 所 有 记录 列表 


{ While (SRow =SResult -Fetch Assoc ()) 
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Sarr[ $count + 站 =$Row; } 
SResult -FEetch Rssoc (); 
® ; // 断 开 连 接 释 放 资 源 


Return $Arr; }?> 
五 、 程 序 设计 题 
1. 根据 下 表 中 的 内 容 , 请 使 用 PHP 语言 ,编写 数据 库 连 接 程序 。 


数据 库 名 称 用 户 名 密码 
MySQL RCZP Root 123 





2. 根据 下 图 内 容 所 示 ,利用 表单 技术 ,编写 一 段 代码 实现 其 效果 ,其 中 Action 属性 值 
设 为 空 ,程序 名 称 自 定义 。 





























3. 根据 下 图 内 容 所 示 ,设置 表 单 属性 值 表 , 其 中 包含 一 个 名 称 为 ShiJian 的 隐 
藏 域 。 





和 
上 是 : 朗 宁 软件 公司 运营 专员 | 
去 次 件 公司 运营 专员 年 加 大约 多 少 9 





内 容 : 








| 修改 | 
4. 根据 下 图 内 容 所 示 ,利用 框架 集 , 编 写 一 段 代码 实现 其 效果 。 





顶 区 : Top. PHP 


左 区 : Left. HTML 浏览 区 : Jieshao. HTML 


5. 根据 教材 中 论坛 表 内 容 , 请 按 以 下 要 求 编写 SQL 程序 代码 。 
查询 文章 主题 字段 包含 "吉林 大 学 "关键 字 的 记录 集 ; 

@ 查询 内 容 字段 包含 “人才 "关键 字 的 记录 集 ; 

@ 查询 结果 按照 文章 序号 字段 排序 。 
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1. 利用 PHP 设计 开发 一 个 人 才 招 聘 BBS 系统 ,需要 哪些 必 备 的 软件 环境 ? 
2. 人 才 招 聘 BBS 系统 ,发 布 的 方式 有 哪些 ? 具体 的 流程 是 什么 ? 
3. 如 何 运营 好 一 个 网 站 ? 
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为 了 学 以 致 用 ,本 章 将 设计 一 个 简单 而 完整 的 人 才 招聘 网 站 。 通 过 前 期 设计 ,数据 库 
建设 ,页 面 制作 和 服务 器 程序 设计 等 基本 过 程 , 掌 握 网 站 的 完整 设计 过 程 。 

通过 该 实例 ,了 解 一 个 网 站 的 实现 过 程 : 

(1) 网 站 的 功能 和 结构 ,应 采用 什么 软件 环境 ? 

(2) 怎么 设计 网 站 的 数据 库 表 ? 

(3) 如 何 实 现 网 站 的 布局 和 代码 重用 ? 如 何在 网 页 中 添加 服务 程序 ? 


14.1 网 站 前 期 设计 


在 建设 网 站 前 要 认真 了 解 相关 行业 ,思考 网 站 的 功能 和 用 户 需求 ,将 网 站 的 构想 落实 
成 网 站 需求 说 明 书 ,并 讨论 网 站 具有 的 特点 和 可 行 性 。 在 明确 网 站 的 需求 和 定位 后 ,对 网 
站 的 整体 风格 功能、 结构 和 开发 环境 进行 前 期 策划 。 

1. 规划 网 站 结构 

由 于 网 站 的 规模 较 小 ,出 于 优化 的 目的 ,采用 层级 较 少 的 网 站 结构 ,将 网 站 的 首页 放 
置 在 网 站 根 目 录 。 建 立 Action 目录 ,放置 网 站 业务 逻辑 和 数据 库 管 理 页 面 ;建立 Images 
和 CSS 目录 ,分 别 存放 组 成 网 页 的 图 像 文件 和 样式 文件 ,如 图 14-1 所 示 。 
网 站 根 目录 


| 


Images 目 录 首页 CSS 目 录 Action 目 录 | 


| 1 


了 
注册 页 面 岗位 信息 页 | [求职 信息 页 | “| 成 绩 管理 页 | 
























































图 14-1 人 才 招 聘 网 站 目录 结构 


2. 规划 网 站 功能 


人 才 招聘 网 站 定位 为 小 规模 的 信息 管理 系统 ,通过 操纵 数据 库 更 新 页 面 , 为 人 才 招聘 
提供 信息 展示 和 交互 的 平台 。 多 数 系统 除了 提供 用 户 登录 的 前 台 页 面 外 ,还 提供 独立 的 
后 台 管 理 系统 ,由 管理 员 用 户 登 录 ,管理 发布 和 维护 网 站 数据 库 。 为 了 简化 设计 ,在 人 才 
招聘 网 站 中 合并 前 后 台 系 统 ,分 公司 和 个 人 两 类 用 户 ,公司 用 户 实现 数据 库 管 理 功能 。 主 
要 页 面 功 能 如 下 。 

(1) 首页 : 用 于 提供 用 户 登录 和 数据 搜索 的 界面 ,展示 网 站 的 最 新 信息 、 广 告 和 联系 
方式 等 内 容 ,通过 导航 栏 可 以 链接 到 其 他 页 面 。 

(2) 注册 页 : 为 个 人 和 公司 新 用 户 提供 网 站 注册 界面 。 

(3) 招聘 信息 页 : 用 于 展示 公司 的 岗位 招聘 信息 和 公司 的 搜索 结果 。 公 司 用 户 可 用 
于 维护 岗位 信息 ;个 人 用 户 可 用 于 申请 具体 岗位 。 

(4) 求职 信息 页 : 用 于 展示 网 站 数据 库 中 的 求职 人 员 信息 和 人 员 搜 索 结果 。 求 职 人 
员 可 用 于 维护 本 人 的 基本 信息 。 

(5) 成 绩 管理 页 : 求职 人 员 登 录 后 可 查看 本 人 的 岗位 成 绩 ;公司 用 户 登录 后 可 录入 
或 查看 所 有 应 聘 人 员 的 岗位 成 绩 。 


3. 选择 开发 环境 及 工具 


作为 一 个 轻 量 级 的 数据 库 系 统 , 安 装 XAMPP 软件 包 获 取 网 站 运行 环境 : Apache 网 
页 服务 器 ,MySQL 数据 库 服务 器 和 PHP 解析 器 。 

通过 HTML 和 CSS 语言 设计 网 页 ,嵌入 PHP 程序 实现 数据 库 操 作 和 网 站 业务 迎 辑 。 
展示 页 面 借助 于 Dreamweaver 的 模板 技术 ,使 网 页 的 风格 一 致 ,布局 相同 ,颜色 统一 ,并 实 
现 网 站 的 快速 制作 。 


4. 设计 数据 库 


作为 一 个 信息 管理 网 站 ,人 才 招 聘 需要 岗位 表 (GWB ) ,应 聘 人 员 表 (YPRYB) .岗位 
成 绩 表 (GWCJB ) 和 公司 表 (GSB)4 个 数据 表 。 招 聘 公 司 提供 招聘 岗位 信息 ,应 聘 人 员 可 
以 申报 岗位 ,并 由 公司 录入 考核 成 绩 以 便 查 询 。 可 用 PHPMyAdmin 平台 管理 这 些 数据 ， 
在 MySQL 数据 库 服务 器 中 创建 RCZP 数据 库 ,并 在 数据 库 内 添加 这 些 数据 表 。 


14.2 网 站 结构 和 模板 设计 


网 站 主要 页 面 均 使 用 统一 的 Logo ,联系 方式 、 导 航 栏 及 页 脚 信息 。 为 了 简化 网 页 设 
计 和 提高 代码 的 重用 性 ,用 Dreamweaver 创建 模板 页 ,再 用 模板 生成 其 他 页 面 ,实现 网 站 
整体 布局 的 规划 ,使 风格 统一 ,易于 维护 。 
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14.2.1 配置 站 点 和 模板 页 


使 用 Dreamweaver 设计 动态 网 站 ,首先 需要 建立 站 点 ,再 创建 模板 页 或 其 他 页 面 , 若 
页 面 需要 数据 支持 还 要 添加 数据 库 连 接 。 人 才 招 聘 网 站 的 初始 设置 如 下 。 

(1) 启动 Dreamweaver, 单 击 “ 站 点 "菜单 一 “新 建站 点 "选项 ,在 “站 点 设置 对 象 " 对 话 
框 中 ,设置 站 点 名 称 为 “人 才 招 聘 ” ,指定 本 地 i 
的 网 站 根 目录 “D;\ 人 才 招 聘 ”。 人 

(2) 在 “服务 器 "设置 对 话 框 中 ,需要 配 连接 方法 ; [二 | 
置 连接 方法 、 服 务 器 文件 夹 和 WebURL, 如 二 RCR | 
图 14-2 所 示 。 在 “高 级 "选项 卡 中 , 设置“ 服 We 
务 器 模型 "为 PHP MySQL, 单 击 “ 保 存 " 按 钮 。 [mn | me 

(3) 单 击 “ 文 件 "菜单 一 “新 建 "选项 ,新 建 
一 个 没有 布局 的 PHP 模版 ,命名 为 
SiteTemplate. php ,默认 保存 在 网 站 Templates 目 
录 下 。 

(4) 单 击 “ 数 据 库 " 面板 一 ”+ ”一 “ Mysql 连接 "选项 ,在 "Mysql 连接 "对话 框 中 设 
置 连接 名 称 为 RCZP ,设置 Mysql 服务 器 的 连接 方式 ,选择 RCZP 数据 库 , 当 测试 成 功 
后 , 单 击 “确定 "按钮 。 生 成 的 数据 库 连 接 程 序 Rezp. php ,默认 保存 在 网 站 Connections 
目录 下 。 

(5) 在 网 站 根 目录 下 ,新 建 Images ,Action 和 CSS 文件 夹 用 于 存放 相关 的 文件 。 


14.2.2 模板 页 的 设计 


人 才 招 聘 网 站 的 页 面 结构 主要 采用 “三 "字形 布局 ,由 标题 区 、 导 航 栏 .内 容 区 和 页 肢 
四 个 区 域 组 成 ,如 图 14-3 所 示 ,其 中 内 容 区 的 布局 和 内 容 根据 不 同 页 面 的 功能 单独 定义 ， 
其 他 区 域 被 主要 页 面 共享 由 模板 页 实现 。 


1. HTML 代码 


在 模板 页 中 ,使 用 Div 元 素 和 Id 属性 定义 了 页 面 的 主要 结构 : 标题 区 Header .导航 栏 
Navarea 内 容 区 Contentarea 和 页 脚 Footer。 其 中 内 容 区 为 可 编辑 区 域 ,通过 注释 中 的 
TemplateBeginEditable 和 TemplateEndEditable 指定 ,没有 元 素 内 容 , 当 使 用 模板 生成 新 页 
面 时 ,可 重新 编辑 该 区 域 的 具体 内 容 。 

在 SiteTemplate. php 的 Body 元 素 内 添加 HTML 代码 ,部 分 代码 如 下 : 


<Div Id="Header" > <! 一 标题 区 --> 
<Div Id="Top logo" > <! 一 标题 区 左边 网 站 Logo --> 





























图 14-2 服务 器 设置 项 





<A Href ="../Index.php" ><Img Src —"../Images/ 人 才 招 聘 .png" Width "400" Height 一 " 


120" Alt 一 人 才 招 聘 " /></R></Div> 


第 协 章 ”人才 招聘 网 站 综合 设计 


(63 





人 才 招 聘 欢迎 登录 人 人才 招聘 网 站 ， 请 登录 或 免费 [注册 ] 


人 服务 电话 。 000-000 


多 


标题 
Talent recruitment 
campus to company 



































FE 进入 人 才 招聘 网 站 首页 | 我们 与 许多 企业 建立 了 友好 的 合作 关系 
| 中 4 ”搜狐 | 优酷 + 豆 集团 
内 容 区 一 [一审 码 : Fs se@HU,.com Youku Tudou Inc. 
回 攻 江 回 EC >。 > 
工 涡 Alibaba Group ”Tencent 肚 读 D 右 | COM 
并 网 里 巴巴 第 加 
用 手机 扫 凡 二 维 码 对 结 中 “其 
页 有 CR 
图 14-3 ”人才 招聘 网 站 首页 布局 
<Div Id= "Top Info" > <! 一 标题 区 右边 信息 栏 --> 


ee <! 一 PHP 代码 提供 的 欢迎 信息 和 注册 接口 --> 
<Div Id="Top tel" >000 -00000000 </Div > 
</Div ></Div ><Hr/ > 


<Div Id ="Navarea" > <! 一 导航 栏 --> 
<Div Id="Nav" > 
<1> <! 一 导航 栏 条 目 --> 


<Li ><A Href ="Index.php" Target =" self" Class ="Select" > 
<Em> 唱 消 页 YB></Em></A><Li> 
<Li > 人 Href ="Zpxx.php" Target =" self" > 
<Em><B 沂 聘 信息 SB></Em></A></Ii> 
<Li ><A Href ="Qzxx.php" Target =" self" > 
<Em> 避 壮 职 信息 YB></Em></A><Li> 
Li > Href +"Cjgl.php" Target = self" > 
<Em> 阳 关 绩 管理 </B></Em></A></Ii> 
<Li > 人 Href ="Qjlt.php" Target =" self" > 
<Em> 悍 头 职 论坛 wB><Em></RA></Li></OL></Div> 
Div Id ="Nav_Bottom" ></Div > 
</Div > 
<Div Id ="Contentarea" > <! -- 主 要 内 容 区 --> 
<! — TemplateBeginEdiTable Name ="contentarea" 一 一 > 
<! -TemplateEndEdiTable 一 -> 
</Div> 
<Div Id ="Footer"> <! 一 脚注 区 --> 
<Div Class = 一 FL -Info" > 
A Href "index.html" 消 页 YA>i: 人 Href 起 凑 于 我 们 wwA>;i Href 二 和 > 
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服务 协议 YAA>;: <A Href 一 "#3 合作 伙伴 </R> | QA Href 二 搓 系 我 们 </R></Div > 
<P Class = 一 FL -copy" >CopyRight gcopy; CCFE Organization, All Rights Reserved </P 
> 

</Div > 


2. CSS 代码 


Div 元 素 要 通过 CSS 代码 定义 每 个 区 域 的 具体 显示 样式 。 单 击 “ 文 件 " 菜 单一 “新 
建 " 选 项 ,新 建 一 个 CSS 页 面 ,命名 为 Content. css 保存 在 CSS 目录 下 ,部 分 代码 如 下 : 


eader { /* 标题 区 样式 * / 

Height: 120px; Width:1000px; Position: Relative;Margin: 10px Auto; } 
op_logo { /* 标题 区 左边 网 站 Logo 样 式 * / 

Float: Left; Margin -Teft :30px; } 
op_Info { Float: Right;Font -Variant: Small -caps; /* 标题 区 信息 栏 样式 * / } 
op tel{ Background:Url(../Images/Phone.gif) No -Repeat 20px 20px ; 
Padding -Left:130px; Padding -Top:20px; Margin — Top: 10px; Font — 

Size:18px; 


Color :FFFFF;Width:240px; Height :50px;Background -Color: 录 AR53RA8; } 
Wav{ Display:Block;Width: 1000px; Height: 34px;Margin: 0px Auto;  /* 导航 栏 样式 * /} 


Hav Ul 1i { Display:inline; /* 导航 栏 选项 以 内 联 元 素 方式 显示 
*/} 
av A{ /* 导航 链接 样式 * / 


Float :Left;Height :24px;Width:Auto; Background:Ur] (../Images/Navbox.gif) No -Repeat; 
Margin -Right :5px; Padding:10px 15px Opx; Font -Size:14px; 
Font -weight :bold; Text -Decoration:None;Color:#66666 } 


av A.Select { /* 导航 链接 选中 时 样式 * / 
Background:Url (. ./Images/Navbox Select .gif) No Repeat;Color: $FF; } 
av_Bottom{ /* 导航 底部 样式 * / 
Width:1000px;Height :5px;Margin:0 Auto; Background -Color :$266CC } 
#Eontentarea { Width:1000px;Margin:0px Auto; /* 主要 内 容 区 样式 * / } 
Pooter { /* 脚注 区 样式 * / 


Clear: Both; Text -Align:Center;Width: 1000px;Margin: 10px Auto; } 


为 了 在 页 面 中 应 用 样式 定义 ,需要 在 SiteTemplate. php 的 Head 元 素 中 添加 代码 引入 
CSS 文件 。 


<Link Rel ="Stylesheet" Type ="Text/CSS" Href ="CSS/Content .css"/ > 


3. PHP 代码 


模板 页 的 标题 区 通过 PHP 代码 显示 不 同 的 欢迎 信息 , 若 用 户 已 登录 , 则 显示 用 户 类 
别 , 并 提供 退出 链接 , 交 给 Action 目录 下 的 Logout. php 程序 实现 。 若 用 户 未 登录 , 则 提供 
注册 页 面 链接 Ze. php。 在 SiteTemplate. php 中 ,Id 名 为 Top_Info 的 Div 元 素 内 添加 如 下 
代码 实现 欢迎 信息 : 
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<?PHP 

If (!Isset($ SESSION) ) Session Start(); // 开始 会 话 

IE ($ SESSION['IsLogin'] = 导 ) 
{ Echo "欢迎 gsNbsp; &Nbsp; ' . $ SESSION["UserName"] . '&Nbsp; ENbsp'; // 用 户 已 登录 
IE ($ SESSION['Role'] ==='Rpry') Echo ' 应 聘用 户 '; 
IE ($ SESSION['Role'] ==='Gs') Echo ' 公 司 用 户 '; 

Echo ' 人 Href "Action/Logout .php" >&Nbsp; &Nbsp; 退 出 登录 </A>'; 

} // 为 用 户 提 供 退 出 链接 

Else // 用 户 未 登录 
Echo ' 欢 迎 登 录 人 才 招 聘 网 站 ,请 登录 或 免费 人 Href ="zc.php" 注册 </A>'; ?> 


14.2.3 用 模板 生成 页 面 


实现 模板 文件 后 ,可 以 在 Dreamweaver 中 引用 模板 创建 网 站 页 面 。 单 击 “ 文 件 " 菜 单一 
“新 建 "一 “模版 中 的 页 "选项 ,选择 “人 才 招 聘 " 站 点 中 的 SiteTemplate 模板 文件 ,使 用 该 
模板 在 网 站 根 目录 下 创建 首页 Index. php ,注册 页 Ze. php .岗位 信息 Gwxx. php .求职 信息 
页 Qzxx. php 和 成 绩 管理 页 Cjgl. php。 

用 模板 生成 的 网 页 ,自动 包含 模板 中 的 布局 ,内容 和 引用 文件 。 这 些 网 页 只 需要 修改 
可 编辑 的 模板 区 域 ,保证 了 网 站 中 风格 的 统一 。 


14.3 首页 和 注册 页 面 设 计 


网 站 首页 是 一 个 网 站 的 入口 页 面 。 人 才 招 聘 网 站 作为 一 个 内 容 管理 系统 ,其 首页 不 
仅 要 提供 指向 其 他 相关 页 面 的 导航 链接 ,也 要 提供 用 户 登 录 和 注册 的 接口 。 


14.3.1 首页 设计 


网 站 首页 通常 是 用 户 看 到 的 第 一 个 页 面 , 除 了 满足 设 定 功能 外 ,还 应 确保 结构 清晰 明 
了 ,方便 用 户 找到 相关 内 容 和 链接 。 

用 模板 生成 人 才 招 聘 网 站 的 首页 ,自动 包含 模板 中 的 基本 模块 : 导航 栏 可 以 链接 到 
其 他 页 面 ;标题 区 的 信息 栏 ,为 新 用 户 提供 注册 页 链接 并 为 已 登录 用 户 提供 退出 接口 。 此 
外 ,在 首页 的 内 容 区 增加 搜索 栏 .用户 登 录 区 和 广告 栏 等 内 容 。 

其 中 搜索 栏 和 用 户 登 录 区 需要 将 用 户 输入 提交 给 业务 逻辑 程序 ,再 跳 转 到 显示 结果 
页 面 。 通 过 Header( "Location: 资源 名 " ) 函数 可 以 实现 浏览 器 页 面 的 重 定向 ,在 资源 名 
后 追加 参数 ,可 以 实现 不 同 页 面 间 的 数据 传递 。 

资源 名 参数 以 问号 *?”" 开 始 ,采用 “参数 名 = 参数 值 "的 格式 追加 在 资源 名 后 ,如 果 有 
多 个 参数 , 则 参数 之 间 用 “&" 符 隔 开 。 如 打开 “Index. php” 页面 并 传递 用 户 名 “ Admin” 和 
密码 “Adm "参数 ， 
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Header( Location: Index.php ?UserName ="'Admin' &Psw='Rdm'”) 。 


目标 页 面 可 以 通过 全 局 变量 $_GET[ “参数 名 ] 获 取 参 数值 。 
14.3.2 搜索 栏 设计 


用 表单 实现 搜索 栏 ,在 文本 框 中 输入 搜索 关键 字 , 单 击 “ 搜 索 " 按 钮 后 开始 检索 ,如 
图 14-4 所 示 。 为 了 满足 用 户 的 需求 ,添加 “职位 "和 “简历 "两 个 单 选 按钮 设 定 检 索 范 围 ， 
表单 数据 提交 给 Action 目录 下 的 搜索 程序 Search. php ,根据 用 户 选 择 ,分别 在 岗位 信息 页 
和 求职 信息 页 中 查询 并 显示 结果 。 


[| 攻 @ 搜索 


图 144 首页 中 的 搜索 栏 模 块 


1. HTML 代码 


在 Index. php 文件 的 内 容 区 Contentarea 中 ,使 用 HTML 代码 定义 搜索 栏 。 搜 索 栏 主 
要 通过 表单 实现 文本 框 . 单 选 按钮 和 提交 按钮 ,部 分 代码 如 下 : 


<Div Class ="Search" > <! 一 搜索 栏 表单 --> 
<Div Class ="Center" > 
<Eorm Class ="SearchForm" Name ="SearchForm" Method ="Get" 
Action ="Action/Search.php" > 
<Input Name ="key" Class ="keyinput" Type ="Text" Value ="" 
Size ="50" Maxlength ="25"/ > 
<Label > <Input Name ="keyType" Type ="Radio" Value ="job" Checked = 
"Checked"/ 半 位 </Label >gNbsp; 
<Label > <Input Name ="keyType" Type ="Radio" Value ="Res"/ ;简历 </Label > 
<Input Name "Sub" Class ="Sh_btn" Type 2"Submit" Value = 搜索 "/ > 
</Form > </Div ></Div > 


2. CSS 代码 
在 Content. ess 文件 中 使 用 CSS 代码 为 搜索 栏 设 定 显示 样式 ,部 分 代码 如 下 : 


.Search{Font -Size:18px;Width:1000px; Background -Color: 晶 266CC; ”/* 标题 区 样式 * /} 


.Search .Center{ /* 表单 控件 区 域 样式 * / 
Margin Teft:20px;Margin -Top:20px;Height :60px;Float: Left; } 
.Search .Center .sh btn{ /* 按钮 样式 * / 


Background -Color: #5B549; Margin Teft: 30px; Text Align: Center; 
Width: 80px;Height: 36px; Line -Height: 36px; Border: Opx; 
Color: FFFFF; Cursor: Pointer; } 
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3. PHP 代码 


在 Search. php 文件 中 ,通过 Header 函数 访问 岗位 信息 页 Gwxx. php 或 求职 信息 页 
Qax. php, 并 通过 资源 名 参数 向 目标 页 面 传递 搜索 关键 字 。 部 分 PHP 代码 如 下 : 
If($ GET[' KeyType’ ] =="'Job') // 根据 用 户 选择 传递 到 不 同 页 面 
Header ("Location: ../Gwxx.php?Key=$ GET[key]") 7 
Else Header ("Location: ../Qzxx.php?Key =$ GET[key]") 
在 岗位 信息 页 中 用 于 查询 搜索 结果 的 部 分 代码 如 下 : 
IE (!FEmpty($ GET["key"])){ $Searchkey ATrim($ GET["key"]); 
SSql ="Select * From Gwb Where 岗位 名 称 Like '$". $Searchkey."%"' or 
聘任 要 求 Like '%$". $Searchkey."%%' or 公司 名 称 Like '%". $SSearchkey."%'"; 
SSearchresult -Mysql query ( $5ql, SRczp); ?> 
在 求职 信息 页 中 用 于 查询 搜索 结果 的 部 分 代码 如 下 : 
If (!Empty($ GET["key"])){ SSearchkey 3ATrim($ GET["key"]); 
SSql ="Select 姓名 , 婚 否 ,所 学 专业 ,Email 账号 ,移动 电话 ,个 人 简历 From YPRYB 
Where 所 学 专业 Like '%". $SSearchkey."%' or 个 人 简历 Like '%". SSearchkey." ?7 
SSearchresult Mysql query ( $5ql, $Rczp); 


14.3.3 用户 登录 区 设计 


用 户 在 登录 区 的 表单 中 输入 注册 信息 进行 登录 ,个 人 用 户 使 用 身份 证 号 和 密码 ,公司 
用 户 使 用 公司 名 称 和 密码 ,如 图 14-5 所 示 。 一 - ] 
表单 数据 提交 给 Action 目录 下 的 登录 处 理 

程序 Login. php , 由 于 用 户 密 码 使 用 明文 传 人 
输 和 存储 并 不 安全 ,所 以 采用 MD5 函数 对 
其 加 密 后 再 实现 用 户 验证 。 用 户 退出 则 通 
过 Logout. php 实现 。 


Li 


在 Index. php 文件 中 使 用 HTML 代码 定 图 14-5 用 户 登录 区 
义 用 户 登录 表单 ,部 分 代码 如 下 : 





用 户 名 : | 请 输入 身份 证 号 或 公司 名 
密码: |e。 








<Div Class ="Login area"> 
<Div Class "Capital" :用 户 登录 </Div><hr/ > 
<div > <Form Name ="Login" Method = Post” Action ="Action/Login.php" > 
<Li 肖 户 名 : <Input Type ="Text" Name ="UserId" Value "请 输入 身份 证 号 或 公司 名 "></ 
Ii > 
i 闪 人 码 : <Input Type -password" Name -password" Value 二 请 输入 密码 "></Ii > 


基于 互联 网 的 数据 库 及 程序 设计 (第 2 版 ) 


<Li Class —"Login -sub" ><Input Type —"Submit" Name 一 Submit" Value 一 立即 登录 " /></ 


i> 

</Form></Div ></Div > 
2. CSS 代码 
在 Content. css 文件 中 使 用 CSS 代码 为 登录 区 设 定 显示 样式 ,部 分 代码 如 下 : 
.Login area{ /* 登录 区 域 样式 * / 


Text Align: Center; Margin -Top:10px; Padding: 10px 10px; 
Background: #3F3F3;Overflow: Hidden;Border:1lpx Solid #dd;} 


.Login area .Capital{ /* 登录 区 标题 样式 * / 
Width:100% ;Height :44px; Line Height: 44px; Font -Size: 20px;} 
.Login area .Login -sub input{ /* 登录 按钮 样式 * / 


Margin -Top:15px; Background: #5B549; Line -Height: 35px; 
Width: 80%; Color: $FFFFF; Border: None; Border Radius: 5px;} 


3. PHP 代码 


在 Login. php 文件 中 ,需要 查询 应 聘 人 员 表 YPRYB 和 公司 表 GSB 以 验证 用 户 信 息 ， 
如 果 存 在 用 户 记录 , 则 登录 成 功 ,并 将 用 户 信 息 保存 在 全 局 变量 $_SESSION 中 ,部 分 PHP 
代码 如 下 : 


$UserId ATrim( $ POST["UserId"]); 
Spassword =Md5 ($ POST["password"]); // 使 用 Ma5 函数 加 密 
$Sql ="Select * From YPRYB Where 身份 证 号 =' 加 serId' And 密码 =' $Spassword'"; 
$Rpryresult -Mysql query ( $5ql, $Rczp) or die (Mysql_error ()) 7 
$5ql ="'Select * From GSB Where 公司 名 称 =' 人 serId' And 密码 =' $password'"; 
$gsresult -Mysql query( $5ql, $Rczp) or die (Mysql_ error()); 
If ( SRow Mysq]l fetch assoc( $Rpryresult)){ // 个 人 用 户 登录 
$ SESSION["IsLogin"] 刁 ; $ SESSION["UserId"] =$UserId; 
$ SESSION["UserName"] =$Row[" 姓 名 "]; $ SESSION["Role"] ='Rpry'; 
Header ('Location: ../Index.php'); } 
Else If( SRow -Mysql fetch assoc ( $gsresult)){ // 公司 用 户 登录 
$ SESSION["IsLogin"] 3; $ SESSION["UserId"] =$serId; 
$_SESSION["UserName"] =SRow[" 名 称 "]; $_SESSION["Role"] ='gs'; 
Header ('Location: ../Index.php'); } 
Else { Echo ' <Font Color ="red" 前 户 名 或 密码 错误 ! </Font >'; } 


在 Logout. php 文件 中 ,可 以 通过 消除 Session 回话 实现 用 户 的 退出 ,退出 后 返回 首页 ， 
部 分 PHP 代码 如 下 : 


$ SESSION Array(); 
Session destroy () ;Header ("Location: ../Index.php'); 
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14.3.4 注册 页 面 设计 


新 用 户 可 以 通过 首页 的 注册 链接 访问 注册 页 面 Zc. php。 注 册页 面 中 为 个 人 用 户 和 
公司 用 户 提供 两 种 注册 方式 ,如 图 14-6 所 示 。 表 单数 据 提交 给 Action 目录 下 的 注册 处 理 
程序 Zetj. php ,分 别 插入 到 公司 表 和 应 聘 人 员 表 中 ,可 以 使 用 Mysql_affected_rows( ) 函数 
判断 数据 表 是 否 修改 成 功 。 











个 人 会 员 注册 企业 会 员 注册 
身份 证 号 : job 企业 匀称 : job 
悚 续 客 码 本 后 宪 友 | 
您 的 真实 好 名 企业 地 址 
移动 电话 注册 日期 :| 年 月 /日 
常用 电子 部 征 : 注册 人 数 ; 
个 人 简历 : 企业 简介 : 
4 4 
天 我 已 两 站 并 同意 [ 注 船 协议] 画 我 已 两 站 并 同意 注册 协议 ] 
注册 个 人 必 户 


图 14-6 用 户 登录 区 


1. HTML 代码 
在 Zc. php 文件 中 ,通过 两 个 表单 实现 用 户 信息 的 输入 ,部 分 HTML 代码 如 下 : 


<Div Class ="Reg box" > 
<Div Class ="Reg tit"> 
<Div Class ="Left" > <Sstrong > 个 人 会 员 注册 </Strong ></Div > 
<Div Class ="Right" > <Strong > 公司 会 员 注册 </strong ></Div ></Div > 
<Table Style ="Margin -Bottom:50px; Margin -Top:30px;" > 
<Tr ><Td Width ="50% " Style =" Border -Right :1px DDDDD solid" > 
<Form Name pe Method = Post” Action ="Action/Zctj .php?Role Rpry" > 
<! 一 个 人 会 员 注册 的 表单 控件 列表 -- 


> 


</Fom></Td> 
<Td Width ="50%$" > 
< 上 orm Name 机 Method = Post” Action ="Action/Zctj ee =gs"> 
ene 一 公司 会 员 注册 的 表单 控件 列表 -- 
六 
</Form></TQ></Tr ></Div > 
2. CSS 代码 
在 Content. css 文件 中 使 用 CSS 代码 为 注册 区 设 定 显示 样式 ,部 分 代码 如 下 : 
.Reg box{ /* 注册 区 窗口 * / 
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Width:1000px; Margin:0 Auto; Border:1px PDDDDD solid; Color: 厦 66666} 
.Reg tit{ /* 注册 区 标题 * / 
Height :50px; Border -Bottom:1px BDDDDD solid; Line Height:50px; 
Padding Teft:30px; Font -Size:14px; } 
-Reg tit .Left{ Float:ILeft ; Width:50%; Height:100%;} 
.Reg tit .Right{ Float:Left ; Width:50%; Height:100%;} 


3. PHP 代码 


在 Zetj. php 文件 中 ,根据 用 户 类 型 ,分 别 检索 应 聘 人 员 表 YPRYB 和 公司 表 GSB 中 数 
据 。 首先 判断 是 否 存 在 待 注册 的 身份 证 号 或 公司 名 称 , 若 不 存在 则 向 数据 表 中 插入 注册 
内 容 ,结束 注册 后 返回 注册 页 面 并 显示 操作 结果 。 

以 个 人 用 户 的 注册 为 例 , 部 分 PHP 代码 如 下 : 


If ($ GET['Role'] =='Rpry'"){ // 当 个 人 用 户 注 册 时 
IE (Empty($_ POST[" 身 份 证 号 "]) 11 Fmpty($_POST[" 密 码 "])) 
Echo' <Font Color ="red" 肖 户 名 或 密码 不 能 为 空 ! </Font >'; 
Else 
{ SSfzh =$ POST[' 身 份 证 号 ']; // 获取 表单 数据 
Sn -Md5 ($ POST[' 密 码 ']); Sm =$ POST[' 姓 名 ']; 
$Yddh =$_POST[' 移 动 电话 ']; ”Sgmail =$ POST['email 账号 ']; 
SGrjl =$_POST[' 个 人 简历 ']; 
SSql ="Select * From YPRYB Where 身份 证 号 =' $sfzh'"; 
SResult Mysq] query ( $5q1); 


If( SNum Mysql num rows ( $result)) // 若 身份 证 号 已 存在 
$Info =" 已 经 存在 该 用 户 "; 
Else{ // 插 入 注册 信息 


$5ql ="Insert Into YPRYB (身份 证 号 ,密码 ,姓名 ,移动 电话 , email 账号 ,个 人 简历 ) 
Values (' $sfzh', ' Mm", ' $xm', ' $yddh', ' Semail',' $grjl1')"; 

$a Mysql_query ( $5ql, Rczp) or Mysql error(); 

If (Mysql affected rows () = 屋 ) $Info 下 "注册 成 功 "; // 判断 数据 是 否 插 入 成 功 


Else ”$Info 一 注册 失败 "; } 
Header ("Location: . ./Zc.php?Info =' $Info'"); } 


在 注册 页 面 ,还 需要 显示 注册 结果 的 提示 信息 ,部 分 PHP 代码 如 下 : 


$Info=$ GET['Info']; // 获取 提示 信息 内 容 
If (!Epty( $Info)) Echo ' Div Class 2"Info" >'. $Info.' </Div >'; 


14.4 岗位 信息 页 设计 


人 才 招 聘 网 站 使 用 岗位 信息 页 Gwxx. php 和 求职 信息 页 Qzxx. php 展示 数据 库 中 的 岗 
位 和 应 聘 人 员 信 息 。 当 公司 用 户 登 录 后 ,可 在 岗位 信息 页 中 登记 招聘 岗位 ,管理 本 公司 的 
岗位 信息 并 查看 岗位 的 招聘 情况 ; 当 个 人 用 户 登 录 后 ,可 以 申报 岗位 。 求 职 信息 页 的 功能 
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相对 简单 ,代码 与 岗位 信息 页 重大 ,这 里 就 不 重复 说 明了 。 
14.4.1 岗位 展示 区 设计 


在 页 面 中 建立 岗位 展示 区 以 显示 数据 库 中 的 岗位 信息 ,如 图 14-7 所 示 , 数 据 来 源 于 
岗位 表 GWB ,可 以 借助 Dreamweaver 的 记录 集 和 动态 表格 实现 快速 设计 。 


启 页 | sse | 关 婉 短语 。 万 红色 昔 。 居 多 i 沦 生 






































全 部 岗位 

岗位 编号 | 岗位 名 称 | 人 数 | 年 薪 ‖ 笔试 日 期 聘任 要 求 公司 名 称 

A0004 会 计 3 110000|2017-05-10 笔试 经 济 学 + 金融 工商 前 进 支行 | 修改 岗位 信息 | 查看 应 聘 情况 
B0003 | 岗 前 培训 师 | 2 |10000||2017-05-08 笔试 经 济 学 + 金融 工商 前 进 支行 | 修改 岗位 信息 || 查看 应 聘 情况 








BO0002 理财 师 12 | 9000 |2017-01-22 笔试 : 经 济 法 + 财务 管理 腾讯 总 公司 
B0001 | 经 理 助 理 | 3 | 1200 |2017-01-21 笔试 : 经 济 学 + 人 力 资源 腾讯 总 公司 
A0002 | 银行 柜员 | 5 | 10000|2017-01-15|| 计算 机 二 级 ， 笔 试 : 金融 + 会 计 学 | 工商 前 进 支行 | 修改 岗位 信息 || 童 看 应 聘 情 况 
下 一 个 最 后 一 页 
登记 新 岗位 


图 14-7 岗位 信息 页 的 岗位 展示 区 





































































































岗位 展示 区 的 设计 过 程 如 下 : 
(1) 设计 展示 区 。 在 Gwxx. php 文件 的 内 容 区 Contentarea 中 ,添加 如 下 HTML 代码 ， 


<Div Class ="Display" > 
<Div Class ="Title" ><Div Class "Left" 3 全 部 岗位 </Div ></Div > 
<Div Class < List” > 

oo <! 一 用 于 添加 展示 区 数据 --> 

</Div ></Div > 


(2) 设计 展示 区 样式 。 在 Content. css 文件 中 添加 代码 : 


.Display { /* 展示 区 窗口 * / 

Width:10 00px; Margin:0 Auto; Margin -Top:8px;Border:1px Solid $4FAFEA; 
Padding -Bottom:5px; } 

.Display .Title{ /* 展示 区 标题 * / 


Height :30px; Background:Ur] (../Images/Titlebg.gif) Repeat -x 0px -239px; 
Border -Bottom:1px Solid $4F4FE4A; Line -Height :30px; Margin -Bottom:6px;} 
.Display .Title .Left{ Height:30px; Float:Left; Width:600px; Padding -Teft:10px; 
Font -weight :bold; Font -Size:14px;} 
.Display .list{ /* 展示 区 数据 表 列 * / 
Line -Height :180%; Text Align:Center;} 

(3) 绑 定 记录 集 。 在 Dreamweaver 中 , 单 击 “ 绑 定 ” 面板 一 ”+ ”一 “记录 集 ” 选 项 , 单 
击 “ 记 录 集 "窗口 的 “高 级 "按钮 ,“ 名 称 " 输 入 RecordsetGW,“ 连接" 设置 为 Rezp, 在 SQL 
文本 域 中 输入 下 面 SQL 语句 : 

SELECT 岗位 编号 , 岗位 名 称 , 人 数 , 年 薪 , 笔试 日 期 , 聘任 要 求 , 公司 名 称 
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FROM Gwb ORDER BY 笔试 日 期 DESC 


单 击 “确定 ”按钮 ,完成 记录 集 RecordsetGW 的 绑 定 。 

(4) 添加 动态 数据 。 定 位 在 展示 区 List 类 Div 元 素 内 , 单 击 “ 插 入 "菜单 一 “数据 对 
象 " 一 “动态 数据 "一 “动态 表格 "选项 ,在 “动态 表格 "窗口 中 选择 记录 集 为 RecordsetGW， 
“显示 记录 ”设置 为 5, 单 击 “ 确 定 ” 按 钮 ,添加 动态 表格 。 

(5) 添加 记录 集 导航 条 。 若 记录 集 数据 较 多 ,不 适合 单 页 显示 时 ,可 以 通过 导航 条 实 
现 记 录 集 的 分 页 显示 。 定 位 在 展示 区 下 方 , 单 击 “插入 "菜单 一 数据 对 象 "一 “记录 集 分 
页 ”一 “记录 集 导航 条 ”选项 , 设 定 记 录 集 为 RecordsetGW , 单 击 “ 确 定 ” 按 钮 ,完成 导航 条 
的 添加 。 


14.4.2 岗位 信息 页 设计 


岗位 信息 页 除了 提供 数据 展示 功能 ,还 要 实现 数据 管理 功能 。 若 用 户 未 登录 , 则 做 出 
提示 ; 若 登 录 为 个 人 用 户 , 则 可 以 选择 岗位 ,通过 Action 目录 下 的 Gwtj. php 程序 实现 ; 若 
登录 为 公司 用 户 , 则 可 以 在 当前 页 中 修改 本 公司 登记 的 岗位 数据 ,也 可 以 跳 转 到 成 绩 管理 
页 Cjgl. php 查看 该 岗位 的 招聘 情况 。 


1. 数据 管理 接口 


在 岗位 展示 区 的 代码 中 ,记录 集 RecordsetGW 的 数据 是 通过 Do While 循环 依次 显示 
的 。 为 了 提供 数据 管理 接口 ,根据 用 户 登录 信息 ,在 每 个 记录 后 添加 相应 链接 ,同时 传递 
当前 记录 的 岗位 编号 ,部 分 代码 如 下 : 


QPHP do { ?> 

<Tr ><Td><?PHP Echo $Row_RecordsetGW[' 岗 位 编号 ']; ?></Td > 
<Td > QPHP Echo 依 ow_RecordsetGW[' 岗 位 名 称 ']; ? ></Td > 
<Td><?PHP Echo $Row_RecordsetGW[' 人 数 ']; ?></Td> 
<Td><?PHP Echo $Row_RecordsetGW[' 年 薪 ']; ?></Td> 
<Td > QPHP Echo $Row_RecordsetGW[' 笔 试 日 期 ']; ? ></Td > 
<Td > QPHP Echo 人 Row_RecordsetGW[" 聘 任 要 求 ']; ?></Td> 
<Td > QPHP Echo $Row_RecordsetGW[' 公 司 名 称 ']; ?></Td > 


<?PHP // 数据 管理 接口 

SGwbh = SRow RecordsetGW[ "岗位 编号 '] 
If($ SESSION['IsLogin'] !341) // 用 户 未 登录 

Echo ' <rd>< Href ~"Index.php" > 登录 后 操作 </A></Td>'; 
ElseIf ($ SESSION["Role'] =="'Rpry') { // 个 人 用 户 功能 

Echo ' <Td > < Href ~"Action/Gwtj .php?Gwbh ="' . SGwbh.'" 3 参加 考试 WA></Td>';} 
ElseIf(($ SESSION['Role'] =='Gs') && ( $Row RecordsetGW[' 公 司 名 称 '] == 

$ SESSION ['UserId'])) 

{ // 公司 用 户 功能 


Echo ' <Td ><A Href ~"Gwxx.php?Gwbh =' . SGwbh.'" > 修改 岗位 信息 SA></Td>'; 
Echo ' <Td > Href ="Cjgl .php?Gwbh = . SGwbh.'" 次 看 应 聘 情 况 YA></Td>'; } </Tr> 
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<?PHP }While ( $Row RecordsetGW -Mysql fetch assoc ( SRecordsetGW) )72 > 


2. 岗位 信息 管理 

当 岗 位 信息 页 的 资源 名 参数 包含 岗位 编号 时 ,表示 公司 用 户 要 修改 岗位 表 中 该 岗位 
的 信息 。 岗 位 信息 的 每 个 字段 通过 表单 的 文本 框 控件 显示 , 主键 所 在 文本 框 为 只 读 
Readonly 属性 ,其 他 文本 框 可 以 被 用 户 修改 , 单 击 表单 的 “提交 "按钮 后 ,表单 数据 传递 给 
Action 目录 下 的 Gwtj. php 完成 数据 库 的 更 新 。 





<?PHP 
If(Isset($ GET['Gwbh'])) 
{ SGubh =$ GET['Gubh']; 
SSq] ="Select * From Gwb Where 岗位 编号 =' SGnbh'"; 
SGw _ modify -Mysql query( $5ql, $Rczp); // 获取 指定 的 岗位 信息 
SRow -Mysql fetch array(Sow modify); 
全; 
Echo" <Form Name ='Gw _ modify' Method ="Post' 
Action ="'Action/Gwtj .php?Gwbh =SGwbh' >"; 
While ( SProperty -Mysql fetch field( $Gw modify)) 
{ // 循环 输出 每 个 字段 的 名 称 和 值 
If ( SProperty ->Primary key =3) // 当前 字段 是 否 主键 
Echo SProperty - >Name . ' <Input Type ="Text" Readonly ="True" 
Name =""' . SProperty - AName.'" Value =2""'. SRow[ $i].'"/><r/>'; 


// 资源 名 参数 是 否 含有 岗位 编号 


Else 
Echo SProperty - Name.' <Input Type ="Text" Name 一 '' . SProperty -MAName.'" 
Value 二 '. SRow[ $1].'"/><r/>'; 
信 + 本 


Echo " <Input Name =' sub' Type ='Submit' Value =" 修 改 '/><Fom>"; }?> 


14.4.3 岗位 信息 提交 页 面 设计 

个 人 用 户 提交 岗位 应 聘 申请 和 公司 用 户 修改 登记 岗位 ,都 是 通过 Action 目录 下 的 岗 
位 信息 提交 页 面 Gwtj. php 实现 数据 库 操 作 的 ,操作 结果 最 后 会 通过 资源 名 参数 传递 回 岗 
位 信息 页 。 

1. 岗位 应 聘 申请 

当 用 户 为 个 人 用 户 , 且 最 后 学 历 和 学 位 满足 所 应 聘 岗 位 的 要 求 , 则 将 岗位 编号 和 个 人 
身份 证 号 添加 到 成 绩 表 中 ,实现 该 岗位 的 应 聘 申请 ,部 分 PHP 代码 如 下 : 

SGwibh =$ GET['Gwibh']; 

If ($ SESSION['Role'] =="Rpry'){ // 是 否 个 人 用 户 


SSql ="Select 最 低 学 历 ,最 低 学 位 ,笔试 日 期 From Gwib Where 岗位 编号 =' $Gwbh'"; 
SGwresult Mysql fetch assoc (Mysq]l query( $5ql, 名 czp)) 7 
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SRyid=$ SESSION[ "UserId']; 
SSql ="Select 最 后 学 历 , 最 后 学 位 From YPRYB Where 身份 证 号 =' SRyid'"; 
SRyresult -ysql fetch assoc (Mysql query( $5ql, $Rczp)); 
If (( SGwresult[" 最 低 学 历 '] <= 人 yresult[' 最 后 学 历 ']) && 
( SGwresult[' 最 低 学 位 '] <=$Ryresult[' 最 后 学 位 '])) 
{ // 是 否 满足 岗位 要 求 
$Sql "Insert Into gwcjb (身份 证 号 ,岗位 编号 ) Values (' $ryid', ' SGwbh') "7 
Mysq] query( $5Sgql, $Rczp); 
IE (Mysql affected rows()! 习 ) $Info 一 岗位 信息 修改 失败 "; 
Else $Info "申请 成 功 ,请 于 Sewresult [笔试 日 期 ] 日 参加 考试 "; } 
Else $Info "申请 失败 ,不 符合 岗位 要 求 "; 
Header ("Location: ../Gwxx.php?Info=$Info"); } 


2. 岗位 信息 修改 
当 用 户 为 公司 用 户 时 , 若 待 修改 岗位 的 公司 名 称 和 当前 用 户 的 名 称 相同 , 则 使 用 岗位 
信息 页 中 的 表单 数据 修改 岗位 表 CWB。 
Elseif ($ SESSION['Role'] =="'gs'){ // 是 否 公司 用 户 
SGsid=$ SESSION['UserId']; ”S$Gwmc =$ POST[' 岗 位 名 称 ']; 
SZdxl =$_POST[' 最 低 学 历 ']; $Zdxw =$_POST[' 最 低 学 位 ']; 
SRs =$ POST[' 人 数 ']; SNLsx =$_POST[' 年 龄 上 限 ']; 
SNx =$ POST[' 年 薪 ']; SBscj =$_POST[' 笔 试 成 绩 比 例 ']; 
$Bsrq =$_POST[' 笔 试 日 期 ']; SPryq =$_POST[' 聘 任 要 求 ']; 
SSql ="Update Gwb Set 岗位 名 称 =' SGwmc' ,最 低 学 历 =' $Zqx1' ,最 低 学 位 =' $zdxw'， 
人 数 =' $SRs' 年龄 上 限 =' SNLsx' ,年 薪 =' SNx'， 笔试 成 绩 比例 =' SBscj '， 
笔试 日 期 =' $Bsrq' ,聘任 要 求 = SPryq' 
Where 公司 名 称 =' SGsiq' and 岗位 编号 =' SGwbh'"; 
Mysql_query ( $5ql, Rczp); 
If (Mysql affected rows()! 习 ) $Info 一 岗位 信息 修改 失败 "; 
Else ”$Info 一 岗位 信息 修改 成 功 "; 
Header ("Location: ../Gwxx.php?Info=$Info"); } 


14.5 成 绩 管 理 页 设计 


人 才 招 聘 网 站 为 用 户 提 供 成 绩 查看 和 管理 功能 ,只 有 登录 用 户 可 以 访问 。 个 人 用 户 
只 能 查看 本 人 所 报 的 岗位 成 绩 ,公司 用 户 可 以 查看 本 公司 全 部 岗位 或 所 选 岗位 的 应 聘 情 
况 , 也 可 以 修改 应 聘 人 员 的 考试 成 绩 。 如 图 14-8 所 示 。 


14.5.1 成 绩 展 示 区 设计 


在 成 绩 管理 页 Cjgl. php 中 建立 成 绩 展示 区 ,用 来 显示 成 绩 表 中 的 数据 ,成 绩 展示 区 
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考试 成 绩 

离 位 编号 | 离 位 名 称 | 。 公司 名 称 身份 证 号 姓名 | 笔试 成 绩 | 面试 成 绩 | 总 分 
A0002 | 银行 柜员 | 工商 前 进 支行 | 229901199503121538 | 刘 德 厚 | ”80 85 ”| 81.5000 | 修改 个 人 成 绩 
A0002 | 银行 柜员 | 工商 前 进 支行 | 229901199305011575 | 赵 明 80 65 | 75.5000 | 修改 个 人 成 绩 
A0002 | 银行 柜员 | 工商 前 进 支行 | 219901199001011351 | 部 帅 70 70 “| 70.0000 | 修改 个 人 成 绩 

















































































































身份 证 号 229901199305011575 

岗位 编号 A0002 | 

资格 审核 0 

笔试 成 绩 80 

面试 成绩 65 | 
成 绩 修改 


图 14-8 成 绩 管理 页 中 修改 个 人 成 绩 














的 实现 过 程 和 岗位 展示 区 相同 ,使 用 Dreamweaver 创建 记录 集 RecordsetCJ 获取 成 绩 表 
GWCJB 中 数据 。 由 于 用 户 类 型 和 资源 名 参数 不 同 ,所 需要 的 数据 源 也 不 同 ,需要 将 
RecordsetCJ 用 于 查询 的 SQL 语句 修改 为 如 下 PHP 代码 ; 


If($ SESSION["IsLogin'"] ! 村) // 用 户 未 登录 
Header ("Location: Gwxx.php?Info="' 请 登录 后 查看 成 绩 '") ; 
Elseif ( $ SESSION['Role'] =="'Rpry') 
{ // 显示 个 人 用 户 应 聘 的 岗位 成 绩 
S$SRyid=$ SESSION['UserId']; 
S$SQuery_RecordsetCJ ="SELECT 岗位 编号 ,岗位 名 称 ,公司 名 称 ,笔试 成 绩 ,面试 成 绩 ， 
笔试 成 绩 * 笔试 成 绩 比 例 /100 4 面试 成 绩 * (1 -笔试 成 绩 比 例 /100) Rs 总 分 FROM 
Gwcjb Natural Join Gwb Where 身份 证 号 =' $Ryid' Order By 总 分 Desc";} 
Elseif($ SESSION["Role'] =='"Gs' && Isset($S GET['Gwbh'])) 
// 显示 公司 用 户 指 定岗 位 成 绩 
Sowbh =$ GET['Gwbh']; 
SRyid=$ SESSION['UserId']; 
SQuery_RecordsetCJ ="SELECT 岗位 编号 ,岗位 名 称 ,公司 名 称 ,身份 证 号 ,姓名 ,笔试 成 绩 ， 
面试 成 绩 , 笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面 试 成 绩 * (1 -笔试 成 绩 比 例 /100) as 总 分 
FROM Gwcjb Natural Join YPRYB Natural Join Gwb Where 岗位 编号 =' SGwbh' And 
公司 名 称 =' $SRyid' Order By 总 分 Desc"; } 
Else 
{ // 显示 该 公司 全 部 岗位 成 绩 
SRyid =$ SESSION['UserId']; 
Souery Recordsetcd "SELECT 岗位 编号 ,岗位 名 称 ,公司 名 称 ,身份 证 号 ,姓名 ， 
笔试 成 绩 ,面试 成 绩 ,笔试 成 绩 * 笔试 成 绩 比 例 /100 + 面试 成 绩 * (1 -笔试 成 绩 比 例 / 
100) 
Rs 总 分 FROM Gwcjb Natural Join YPRYB Natural Join Gwb 
Where 公司 名 称 =' Ryid"' Order By 总 分 Desc"; } 
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14.5.2 成 绩 管理 功能 设计 


公司 用 户 可 以 查看 本 公司 岗位 的 成 绩 信 息 , 并 为 每 个 应 聘 人 员 录 入 成 绩 。 为 实现 此 
功能 ,需要 为 每 项 成 绩 添 加 管理 链接 ,通过 表单 修改 所 选 人 员 的 成 绩 ,传递 给 Action 目录 
下 的 Cjtj. php 实现 数据 库 的 修改 。 


1. 成 绩 管 理 链接 


成 绩 展示 区 使 用 动态 表格 显示 记录 集 RecordsetCJ。 为 了 实现 成 绩 管理 ,需要 在 循环 
体内 在 为 每 个 记录 添加 管理 链接 ,并 通过 资源 名 参数 传递 的 岗位 编号 $ Gwbh 和 身份 证 
号 $$xgsfzh ,以 便 确定 应 聘 人 员 和 岗位 ,部 分 PHP 代码 如 下 : 

If(($ SESSION['Role'] =='Gs') && ( $Row Rec ordsetCJ[' 公 司 名 称 '] ==$_SESSION['UserId 

"1)) 

Echo ' <Td > & Href ="Cjgl .php?Gwibh =" . $6wbh. ' gxXgsfzh =" . $Sfzh.'" > 
修改 个 人 成 绩 </R></Td >'; 


2. 成 绩 管理 表单 


在 成 绩 管 理 页 中 , 若 资源 名 中 包含 待 修改 成 绩 的 身份 证 号 和 岗位 编号 则 显示 表单 用 
于 用 户 的 成 绩 管 理 , 表 单数 据 提交 给 Cjtj. php 文件 ,部 分 PHP 代码 如 下 : 


IE(Isset($ GET["Gwbh'])&&Isset($S GET['xgsfzh'])) // 是 否 显示 修改 成 绩 表单 
{ Sewbh =$ GET['Gwbh']; 
SSfzh =$ GET['Xgsfzh']; 
SSq] ="Select * From gwcjb Where 岗位 编号 =' SGwbh' And 身份 证 号 =' $sSfzh"'"; 
$Cj modify -Mysql query( $5ql, Rczp); 
SRow Mysql fetch array( $j modify); 
Echo " <Form Name ="'Cj modify 'Method =" Post ' Action ="Action/Cjtj.php?Gwbh = SGwbh 
9 
$00; 
While ( SProperty Mysql fetch field( $Cj modify)) 
{ If ($Property ->Primary key =34) 
Echo SProperty -AName.' <Input Type ="Text" Readonly ="True" 
Name ="" . SProperty -Aame.'" Value ="". $SRow[ $i].'"/><r/>'; 
Else 
Echo SProperty - >Name.' <Input Type ="Text" Name =" . SProperty -MAName.'" 
Value =""'. $SRow[ $i].'"/><r/>'; 
站 二 本 
Echo " <Input Name ='Sub' Type ='Submit' Value =' 成 绩 修改 '/ ></Fom>"; } 


3. 数据 库 更 新 
在 Cjtj. php 文件 中 ,获取 成 绩 信息 页 中 的 表单 数据 , 当 岗 位 表 GWB 中 岗位 编号 所 对 


应 的 公司 名 称 和 公司 用 户 的 名 称 一 致 时 , 则 修改 成 绩 表 GWCJB 中 数据 ,并 返回 修改 状态 
信息 。 

If ($ SESSION['Role'] =="'Gs") 

{ S$Gsid=$ SESSION['UserId']; $6fzh =$ POST[' 身 份 证 号 ']; 


SGwbh =$_POST[' 岗 位 编号 ']; $Zgsh =$ POST[' 资 格 审 核 ']; 

$Bscj =$ POST[' 笔 试 成 绩 ']; SMscj =$ POST[' 面 试 成 绩 ']; 

$Sq] "Update Gwcjb Natural Join Gwb Set 资格 审核 =' $Zgsh' ,笔试 成 绩 =' $Bscj'， 
面试 成 绩 =' SMscj' Where 身份 证 号 =' SSfzh' And 岗位 编号 =' SGwbh' And 
公司 名 称 =' SGsid'"; 

Mysql_query ( $5ql, $SRczp); 

If (Mysql affected rows()! 习 ) ”$Info 一 "岗位 信息 修改 失败 "; 

Else ”$Info 一 岗位 信息 修改 成 功 "; 

Header ("Location: ../Cjgl .php?Info=$Info");} 


习 题 


一 、 填空 题 

1. 网 站 通过 检索 数据 库 更 新 页 面 内 容 , 并 提供 数据 库 记 录 的 新 增 、 更 新 和 删除 等 操 

2. 用 户 登 录 和 注册 时 ,如 果 密 码 使 用 明文 存储 和 传输 容易 发 生 泄漏 ,所 以 通常 要 对 
其 加 密 ,PHP 中 常用 函数 实现 数据 加 密 。 

3. 使 用 Dreamweaver 创建 名 为 RCZP 的 数据 库 连 接 , 会 自动 生成 中 文件 ,默认 保 
存在 站 点 的 _@_ 目录 下 。 

4. 在 人 才 招聘 网 站 中 ,用 户 分 为 公司 用 户 和 应 聘 人 员 用 户 两 类 ,其 中 公司 用 户 的 信 
息 存储 在 _Q@ 数据 表 中 ,使 用 _@ 字段 作为 主键 ;应 聘 人 员 存 储 在 _@ 数据 表 中 ， 
使 用 _@_ 字 自作 为 主键 。 

和 Dreamweaver 模板 的 可 编辑 区 ,是 通过 在 模板 代码 中 添加 注释 中 和 @ 定 
义 的 ,还 可 以 在 注释 中 为 该 区 域 指定 名 称 。 

6. 要 实现 浏览 器 页 面 的 重 定向 ,如 从 当前 页 面 跳 转 到 index. php 页 面 , 可 以 通过 PHP 
中 的 _@_ 函数 实现 ,并 设置 函数 参数 为 _@ _: index. php。 

7. 人 才 招 聘 网 站 中 ,为 了 输出 年 薪 大 于 1000 的 岗位 名 称 和 公司 名 称 ,并 按照 笔试 日 
期 降序 排列 ,需要 使 用 下 面 的 SQL 语句 实现 : Select 岗位 编号 ,岗位 名 称 ,公司 名 称 From 
GWB 中。 公司 表 Where 年 薪 >1000 _@) 笔试 日 期 Desc。 

8. 网 站 用 户 登 录 时 ,首先 根据 用 户 名 和 密码 设计 SQL 语句 ,通过 ”Q@ ”函数 执行 ,车 
有 查询 结果 , 则 需要 通过 ”@ 函数 开启 会 话 。 

9. 网 站 通过 检索 数据 库 更 新 页 面 内 容 ,并 提供 数据 库 记 录 的 新 增 、 更 新 和 删除 等 操 
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二 、 单 选 题 
1. 下 面 关于 在 Dreamweaver 中 制作 动态 网 站 的 描述 ,错误 的 是 ( Ne 
A. Dreamweaver 本 身 不 能 执行 动态 网 页 
B.Dreamweaver 可 以 通过 绑 定 记录 和 集 访问 数据 库 
C.Dreamweaver 需要 为 每 个 动态 页 面 生成 不 同 的 CSS 文件 
D. Dreamweaver 可 以 快速 添加 数据 库 显示 表 格 
2. 使 用 模板 可 以 快速 生成 页 面 , 下面 关于 Dreamweaver 中 模板 的 叙述 错误 的 
是 ( js 
A. 模板 文件 的 默认 保存 路 径 是 网 站 的 Templates 目录 
B. 模板 可 以 提高 网 页 的 重用 性 
C. 模板 适合 于 布局 和 风格 统一 的 网 站 
D. 模板 中 不 可 以 添加 PHP 代码 
3. 通过 网 页 向 数据 表 中 添加 记录 和 修改 记录 时 ,下 面 SQL 语句 中 用 不 到 ( js 
A. Replace B. Insert C. Update D. Alter 
4. 如 果 要 使 用 资源 名 参数 ,向 网 页 Index. php 中 传递 用 户 名 和 密码 数据 , 值 为 Admin 
和 AdmValue ,所 对 应 的 资源 名 应 为 ( We 


A. index. php? username = Admin&password = AdmValue 





B. index. php? username:Admin&password: AdmValue 
C. index. php&username: Admin? password:AdmValue 
D. index. php&username = Admin? password = AdmValue 
5. 在 PHP 代码 中 ,可 以 通过 多 种 方式 判断 一 个 变量 是 否 存 ,在 下 面 函 数 中 不 能 判断 
变量 存在 的 是 ( ) 。 
A. JIsset( ) B. Empt() 
C. ISNULL() D. Mysql_Query() 
6. 程序 设计 语言 借助 注释 对 语句 加 以 说 明 ,下 面 关于 注释 的 叙述 错误 的 是 ( ) 。 
A. /* 注释 */ 是 PHP 语言 的 注释 
B. < ! 一 注释 -- > 是 HTML 语言 的 注释 
C. /* 注 释 */ 是 CSS 语言 的 注释 
D. // 注 释 是 SQL 语言 的 注释 
7. 用 PHP 语句 修改 数据 表 记 录 时 ,通过 ( ) 函数 判断 数据 是 否 修改 成 功 。 
A. Mysql_query() B. Mysql_error( ) 
C. Mysql_affected_rows( ) D. Mysql_num_rows() 
8. 用 户 在 搜索 栏 中 输入 关键 字 , 为 了 在 岗位 表 GWB 中 检索 相关 岗位 ,将 关键 字 存 在 
$ key 变量 后 ,请 补 完 SQL 语句 : Select * From Gwb where 岗位 名 称 ( Wa 
A. = $key B. like ? $ key? 
C. like % $ key D. Like % $ key% 
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三 、 多 选 题 
1. 网 站 建设 中 要 先后 经 历 多 个 阶段 ,在 制作 网 站 首页 之 前 ,通常 需要 先 完成 ( ) 
过 程 。 
A. 搜索 引擎 优化 B. 数据 库 设计 C. 业务 逻辑 实现 
D. 需求 分 析 E. 数据 表 操 作 F. 页 面 风格 设计 
2. 在 PHP 页 面 中 包含 代码 Header(“ Location: A. php? type = gs&userid = zhang”) ， 
下 面 关 于 该 代码 的 叙述 错误 的 是 ( ) 。 
A. 用 于 实现 从 当前 页 面 跳 转 到 a. php 页 面 
B. 该 语句 包含 两 个 资源 名 参数 
C. 可 以 在 当前 网 页 中 通过 $_GET 变量 获取 参数 值 
D. 可 以 省 略 Location 实现 相同 的 功能 
E. 省 略 ? 后 面 的 字符 串 内 容 , 也 可 实现 页 面 跳 转 
3. Dreamweaver 可 以 通过 记录 集 实现 网 站 和 数据 库 的 连接 ,为 了 在 网 页 中 添加 记录 
集 , 需 要 首先 设置 ( )。 
A. 创建 站 点 B. 创建 数据 库 连 接 C. 创建 表单 
D. 设置 测试 服务 器 E. 添加 服务 器 行为 
4. 在 下 面 的 CSS 属性 设置 中 ,可 能 会 造成 文档 流 中 元 素 默认 显示 方式 发 生 改 变 的 是 
( ) 。 
A. Float: Left B. Clear: Left C. Cursor: Pointer 
D. Display: inline  E. Padding-Left F. Display:Block 
5. 通过 成 绩 管理 页 的 表单 修改 岗位 成 绩 数据 时 ,( ) 字 段 需要 被 设置 为 只 读 , 不 


允许 用 户 修改 。 
A. 身份 证 号 B. 资格 审核 C. 笔试 成 绩 
D. 面试 成 绩 E. 岗位 编号 


1. 怎样 设计 PHP 程序 ,能 让 企业 用 户 统计 出 总 分 大 于 60 分 的 人 数 ? 
2. 如 何 将 论坛 页 面 加 入 到 人 才 招 聘 网 站 中 ? 
3. 如 果 使 用 PHP 函数 设计 人 才 招 聘 网 站 ,应 该 如 何 修改 ? 
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MySQL 常用 运算 


表 A-1 MySQL 常用 数值 运算 符 及 函数 






































运算 符 及 函数 格式 功能 及 说 明 应 用 示例 
<m>+<m> 加 法 运算 5+2.8 值 为 7.8 
<m>- <m> 减法 运算 5 -2.8 值 为 2.2 
<m>* <nm> 乘法 运算 5 *2.8 值 为 14 
<m>/<m> 除法 运算 5/2 值 为 2.5 
<n>Div<n, > 商 运算 5 Div 2 值 为 2 
<m>% <m > 模 运 算 5%2 值 为 1 
Abs(x) 计算 x 的 绝对 值 Abs( -5) 值 为 5 
Bin(x) 返回 x 的 二 进 制 格式 字符 串 Bin(20 ) 值 为 "10100" 
Ceiling(x) 大 于 或 等 于 x 的 最 小 整数 Ceiling(2.8) 值 为 3 
Exp( x) 计算 e 的 x 次 方 Exp(2) 值 为 7.38905609893065 
Floor( x) 小 于 或 等 于 x 的 最 大 整数 Floor(5.8) 值 为 5 
Greatest(n ,nz na) 所 有 nm 值 的 最 大 值 Greatest(1,2,5 ,4,3) 值 为 5 





Least(n, ,nz ,……na) 


所 有 nm 值 的 最 小 值 


Least(1,2,5,4,3) 值 为 1 





Ln(x) 


以 e 为 底数 ,x 值 的 对 数 


Ln(2) 值 为 0.6931471805599453 





Log(x) 或 Log(x,y) 


以 2 为 底数 ,x 的 对 数 
以 x 为 底数 ,y 的 对 数 


Log(28) 值 为 3.332204510175024 
Log(2,65536 ) 值 为 16 














Mod(n ,nm ) mi 除 以 m 的 余数 Mod(5,2) 值 为 1 
Pi() 圆周 率 pi 的 值 Pi( ) 值 为 3. 141593 
oe 指数 函数 ,返回 x 的 y 次 方 的 值 ， Power(2,5 ) 值 为 32 
x 和 y 的 值 均 为 实数 Power(2,1/2) 值 为 1.4142135623730951 
Rand( ) 0 到 1 之 间 的 随机 值 Rand( ) 值 为 0. 1824410643265 





Round(n ,nz ) 





n 的 值 在 m 指定 位 置 四 舍 五 入 ， 
m 为 正 数 表示 小 数 点 后 的 位 置 ， 


为 负数 表示 小 数 点 前 面 的 位 置 





Round(2.56,1) 值 为 2.6 
Round(12345. 6888, -2) 值 为 12300 


( 续 表 ) 








运算 符 及 函数 格式 功能 及 说 明 应 用 示例 
Sign(x) x 值 的 符号 ( -1.0 或 1) Sign( -5) 值 为 -1 
Sqrt(x) x 值 的 算术 平方 根 Sqrt(16) 值 为 4 





Truncate(n ,n, ) 


函数 格式 


mi 截 短 为 n, 位 小 数 的 结果 ,不 进 
行 四 舍 五 入 





表 A-2 ”MySQL 常用 字符 串 函数 
功能 及 说 明 


Truncate(58.2985 ,2) 值 为 58.29 
Truncate( 123.456, -1) 值 为 120 


应 用 示例 





Ascii( str) 


str 字符 串 首 字 符 的 ASCII 码 值 


Ascii("abc" ) 值 为 97 





Bit_Length( str) 


str 字符 串 的 二 进 制 位 长 度 


Bit_Length("abc" ) 值 为 24 
Bit_Length( "计算 机 " ) 值 为 48 





Char(m [ ,m…]) 


编码 转 字符 并 连接 函数 。 将 各 个 参数 
(编码 ) 对 应 的 字符 接 成 一 个 字符 串 
作为 函数 的 返回 值 


Char(73,32,67,65,78) 值 为 "I 
CAN" 





Char_Length( str) 


字符 串 长 度 函 数 。 返 回 str 字符 串 中 
符号 的 个 数 (也 称 字符 串 长 度 ) ,英文 
符号 汉字 和 全 角 符号 都 记 为 1 


Char_Length(" Data Base" ) 值 为 9 
Char_Length( "数据 库 " ) 值 为 3 





Concat( si ,sa ,ss) 


将 各 字符 串 顺 序 连 接 成 一 个 新 的 字 
符 串 


Concat(" 人才" , "招聘 " ) 值 为 " 
人 才 招 聘 " 





Concat_WS(sep,siys 


sn) 


将 各 字符 串 连 接 成 一 个 新 字符 串 , 并 
用 sep 指定 的 字符 间隔 


Concat _WS("-"," 吉 "," 林 "， 
"省 " ) 值 为 " 吉 - 林 -省 " 





CONV(x,m,n) 


数 制 转换 函数 。x 为 大 于 或 等 于 0 的 
整数 ,将 x 的 值 由 当前 进 制 m( <36) 
转化 到 目标 进 制 n( <36) ,结果 以 字 
符 串 格式 返回 


CONV(30,10,16) 值 为 "1E" 
CONV(12,8,2) 值 为 "1010" 





ELT(n,si[ ,ss ,ss]) 


数码 转 名 称 函 数 。n 为 数值 或 数字 串 
的 字符 表达 式 , 当 1<n<m 时 ,返回 
s, 的 值 ,否则 ,返回 值 为 NULL。 一 般 
用 于 将 数据 编码 转换 成 名 称 


ELT(2， 男 ", 女 ' ) 的 值 为 ' 女 
ELT( 最 后 学 历 无 要 求 " "专科 
,本 科 ' 研究生" 博士" ) 值 为 
最 后 学 历 取 值 的 汉字 名 称 





Jnsert( str, ,x ,y, str, ) 


将 字符 串 str, 从 第 x 位 置 开始 的 连续 
y 个 字符 替换 为 字符 串 str, ,返回 结果 


Insert( " abcde" ,2,2, " 12345" ) 
值 为 "al2345de" 





InSTR( str, , str, ) 


子 串 位 置 函 数 。 若 st 的 值 是 sm 中 
的 完整 子 串 ( 英 文字 母 不 区 分 大 小 
写 ) , 则 函数 返回 其 首次 出 现 的 位 置 
号 ,否则 ,函数 返回 值 为 0 


InSTR(' 吉 林 省 大 学 ',' 吉林 大学 
') 值 为 0 

InSTR( 吉林 省 大 学 ， 大 学 ' ) 的 
值 为 4 





Find_In_Set( str,list) 


分 析 逗 号 分 隔 的 list 列表 ,如 果 发 现 
str, 返 回 str 在 list 中 的 位 置 


Find_In_Set( "ab" ," aa, abc, ab, 
mdd" ) 值 为 3 





Format(X,n) 





转换 千 分 位 函数 ,将 X 的 数值 转换 成 
千 分 位 字符 串 , 其 中 m 为 转换 后 的 小 
数位 数 ,n<0 时 按 0 计算 ,在 小 数 n+ 
1 位 上 四 舍 五 人 





Format ( 23456789. 675, 2 ) 值 为 
"23 ,456,789. 68" 

Format ( 8976.54，- 2 ) 值 为 
"8,977" 
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( 续 表 ) 











函数 格式 功能 及 说 明 应 用 示例 
返回 将 str 字符 串 中 所 有 大 写字 母 改 SR wbon 
Lease( str) 或 Lower( str) 变 为 小 写字 母后 的 结果 Lower(" AbC" ) 值 为 "abc 
Left( str, x) 返回 str 字符 串 中 左边 x 个 字符 Left(" DateTIME" ,4) 值 为 "Date" 
返回 str 字符 串 中 的 字符 个 数 ,每 个 汉 PE 
Length( str) 字 或 全 角 符号 为 2 个 字符 长 度 a 抽 





Locate( str, , str, ,n) 


子 串 位 置 函数 。 从 起 始 位 置 n 之 后 ， 
车 str, 的 值 是 str, 中 的 完整 子 串 ( 英 
文字 母 不 区 分 大 小 写 ) , 则 函数 返回 
其 首次 出 现 的 位 置 号 ,否则 ,函数 返回 
值 为 0 


Locate( 中国" ,中国 是 一 个 发 展 
中 国家 ' ,5) 值 为 8 
Locate( "发 家 ' ， 中 国 是 一 个 发 展 
中 国家 ' ,3 ) 值 为 0 





Ltrim( str) 


将 str 字符 串 开 头 的 空格 去 除 


Ltrim(" 
招聘 " 


人 才 招 聘 " ) 值 为 "人 才 





Mid(str,n[ ,m] ) 或 
SubString( str,n [ ,m]) 


返回 值 是 从 字符 串 str 中 第 n 个 位 置 
开始 向 后 的 m 个 字符 构成 的 字符 串 。 
若 不 写 " ,m" 或 m 值 超过 后 面 的 字符 
个 数 , 则 函数 返回 值 为 从 位 置 n 开始 
向 后 的 全 部 符号 串 


Mid(" 吉 林 省 大 学 " ,3 ) 的 值 为 " 
省 大 学 " 

SubString(" 吉林 省 大 学 " ,3,2) 的 
值 为 "省 大 " 





Position( str in str, ) 


返回 字符 串 str, 在 字符 串 str, 中 第 一 
次 出 现 的 位 置 


Position( "管理 " in "人 才 招 聘 管 
理 系统 " ) 值 为 5 





Quote( str) 


用 反 斜 杠 转 义 字符 串 str 中 的 单 引号 


Quote(" Abc' abe" ) 值 为 " Abc \ 
abecy" 





Repeat( str,x) 


返回 str 字符 串 重复 x 次 的 结果 字 


Repeat(" 人才" ,3 ) 值 为 "人 才 人 
才 人 才 " 





Reverse( str) 


返回 题 倒 str 字符 串 的 结果 字符 串 


Reverse(" ABC" ) 值 为 "CBA" 
Reverse(" 人 才 招 聘 " ) 值 为 " 聘 招 
示人" 





Right( str ,x) 


返回 str 字符 串 中 最 右边 的 x 个 字符 


Right( "abede" ,2) 值 为 "de" 
Right(" 人 才 招 聘 " ,2) 值 为 " 招 
聘 " 





Rtrim( str) 


返回 去 除 str 字符 串 尾部 空格 的 结果 
字符 串 


Rtim( " 人 才 招 聘 
才 招聘 " 


") 值 为 "人 





Stremp( str , str, ) 


比较 字符 串 st 和 str, ,其 中 的 英文 字 
母 不 区 分 大 小 写 ,两 个 字符 串 相 同 , 结 
果 为 0 


Stremp( "abc" , "abd" ) 值 为 = 
Stremp("abe" , "Abe" ) 值 为 0 








Trim( str) 返回 去 除 str 字符 串 首部 和 尾部 空格 | Trim(" 人 才 招 聘 ") 值 为 
区 的 结果 字符 串 "人 才 招 聘 " 
Uecase( str) 或 Upper( str) 返回 将 st 字符 串 中 所 有 字符 转变 为 Upper( "aBe123" ) 值 为 "ABC123" 





大 写 后 的 结果 
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表 A-3 MySQL 常用 比较 .逻辑 运算 符 及 函数 








运算 符 及 函数 格式 功能 及 说 明 应 用 示例 
判断 式 1 的 值 是 否 等 于 式 2 的 值 , 若 | ,A，_ ,av 值 为 1 

< 式 1> = < 式 2> 相等 结果 为 1, 否则 为 0, 式 中 英文 字 | 10 10 0 值 为 1 
母 不 区 分 大 小 写 

A 判断 式 1 的 值 是 否 不 等 于 式 2 的 值 , | "A" < >"a" 值 为 0 
若 不 等 则 结果 为 1 ,否则 为 0 10 < >20 值 为 1 





< 哉 3 和 或 25 


与 " =" 的 区 别 仅 在 于 含 Null 运算 
项 ," < = >" 运 算 项 之 一 是 Null 时 ， 


结果 是 0; 两 项 均 为 Null 时 ,结果 是 1 


5< = >Null 值 为 0 
Null < = > Null 值 为 1 
Null = Null 值 为 Null 





< 起 13> <<< 或 23> 


判断 式 1 的 值 是 否 小 于 式 2 的 值 , 若 
式 1 小 于 式 2 则 结果 为 1 ,否则 为 0 


3 <5 值 为 1 
"A" <"a" 值 为 0 





< 起 15 过 = 起 23 


判断 式 1 的 值 是 否 小 于 或 等 于 式 2 的 
值 , 若 式 1 小 于 或 等 于 式 2 则 结果 为 
1 ,否则 为 0 


3< =5 值 为 1 
"Abc" < "ade" 值 为 1 





< 起 上 > 二 < 式 2> 


判断 式 1 的 值 是 否 大 于 式 2 的 值 , 若 
式 1 大 于 式 2 则 结果 为 1, 和 否则 为 0 


3 >5 值 为 0 
"Abc" >" ade" 值 为 0 





和 


判断 式 1 的 值 是 否 大 于 或 等 于 式 2 的 
值 , 若 式 1 大 于 或 等 于 式 2 则 结果 为 
1 ,否则 为 0 


3> =5 值 为 0 
"Abc" > ="ade" 值 为 0 





< 式 1>Between < 式 2 > And 
去 式 3> 


判断 式 1 的 值 是 否 在 式 2 的 值 和 式 3 
的 值 之 间 


笔试 成 绩 Between 60 And 100 
# 笔 试 成 绩 在 60 ~ 100 之 间 





< 式 1 >In (< 表达 式 表 >) 


判断 式 1 的 值 是 否 等 于 表达 式 表 中 某 
个 表达 式 的 值 


民 厂 码 In ("01","02"," 
03") 

# 民 族 码 为 "01" "02" 或 "03" 
笔试 成 绩 In (57,58 ,59) 

# 笔 试 成 绩 为 57 .58 或 59 分 





< 字段 名 >Is [Not] Null 


字段 名 为 Null 


民族 码 Is Null 





两 个 字符 串 匹配 ,str, 字符 串 中 可 包 


聘任 要 求 like" % 计算 机 %" 








str, Like stm 含 "%" (表示 任 意 多 个 字符 ) 和 下 画 | # 有 对 于 计算 机 能 力 的 聘任 

线 "_"( 表 示 任 意 一 个 字符 ) 要 求 
Cg i 姓名 Regexp "“ 马 " 

正则 表达 式 匹 配 查询 ,可 以 使 用 多 种 - 

str, Regexp str, tl # 匹配 所 有 姓 " 马 " 的 招聘 
正则 表达 式 通 配 符 人 员 

_ 逻辑 非 运算 ,作用 于 逻辑 数据 时 其 值 
1!1< 式 1> ， !( 考 试 成 绩 > =60) 
Naz 式 1> 取 反 ,作用 于 数值 型 数据 时 ,其 值 非 0 # 考 试 成 绩 不 及 格 


结果 返回 0, 其 值 为 0 结果 为 1 





< 式 1>&&< 式 2> 
< 式 1> And < 式 2> 





逻辑 与 运算 , 式 1 和 式 2 同时 为 True， 
结果 为 True, 否则 结果 为 False; 表达 
式 为 数值 型 数据 时 , 非 0 为 True,0 
为 False 





笔试 成 绩 > =60 && 面试 成 
绩 > =60 
# 笔 试 和 面试 成 绩 均 及 格 
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运算 符 及 函数 格式 


功能 及 说 明 


( 续 表 ) 
应 用 示例 





< 式 1> ‖ < 式 2> 
< 起 15.0r 志 式 2> 


逻辑 或 运算 , 式 1 和 式 2 至 少 一 个 为 
True ,结果 为 True ,否则 结果 为 False 


笔试 成 绩 < 60 11 面试 成 绩 
<60 








# 笔 试 或 面试 成 绩 不 及 格 

异 或 运算 , 当 其 中 一 个 表达 式 是 True | 笔试 成 绩 > =60 Xor 面试 成 
< 式 1> Xor < 式 2> 而 另外 一 个 表达 式 是 False 时 ,运算 结 | 绩 > =60 

果 为 Tue, 否则 为 False # 笔 试 或 面试 成 绩 单 项 合格 

如 果 expr 是 True (expn < >0 且 If( 笔试 成 绩 > 面试 成 绩 , 笔 
于 (expr ,expr ,expr ) expr < > NULL) ,那么 ff( ) 函数 返回 试 成 绩 ,面试 成 绩 ) 

i ' # 取 笔 试 成 绩 和 面试 成 绩 中 
expr ,否则 返回 expr 的 较 大 值 





IfNull(expr ,expr, ) 


如 果 expr 不 是 NULL, HNull( ) 函数 
返回 expr ,否则 返回 expr 


HNull(1,0) 结 果 为 
HNull(1/0,10) 结 果 为 10 





Nulllf( expr, ,expr, ) 


如 果 expr, 等 于 expr, ,NullIf( ) 函数 返 
回 NULL ,否则 返回 expm 


NullIf(1 ,1) 结 果 为 NULL 








Case 攻 
ase 
Wi 区 oe 如 果 test, (1<mn) 是 True, 则 返回 | When 1 >0 Then "Truen 
J nn 表达 式 result, 的 值 ,否则 返回 default | When 1 <0 Then "False" 
. 的 值 。 若 多 个 test, 的 值 为 True, 则 只 | Else "Unknown" 
When [test, ] Then [ result, ] . i i 
em Tet) 返回 第 一 个 满足 条 件 的 Result 结果 。 | End 
Else [ default] # 结 果 为 Tue 
End 
Case [test] 
When [ val ] Then [result ] ee 





When [val, ] Then [result, ] 


When[ val, ] Then [result, ] 
Else [ Default] 


如 果 val(1<m<n) 和 test 相等 , 则 
返回 表达 式 result, 的 值 ,否则 返回 
Default 的 值 








When 1 Then "One" 
When 2 Then "Two" 
Else " More" 

End# 结果 为 One 








End 
表 A-4 MySQL 常用 日 期 时 间 函 数 
函数 格式 功能 及 说 明 应 用 示例 
日 期 加 天 数 函 数 。 返回 Date 加 nn 
天 的 日 期 (时 间 ) ,n <0 时 ,得 到 Inl | AddDate(" 2016-10-01" , 100 ) 结果 
Me Date ny 天 前 的 日 期 (时 间 ) ;n=0 时 ,得 到 | 为 "2017-01-09" 


n 天 后 的 日 期 (时 间 ) 。 函 数 返 回 值 
的 数据 类 型 由 Date 的 数据 类 型 
决定 


AddDate( "2016-10-01" ,-100 ) 结果 
为 "2016-06-23" 





Curdate( ) 或 
Current_Date( ) 





返回 当前 的 系统 日 期 ,结果 为 字 
符 串 





Curdate( ) 
# 若 当前 日 期 为 2016-10-1, 则 结果 
为 "2016-10-01" 
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~ 


函数 格式 


功能 及 说 明 


( 续 表 ) 
应 用 示例 





Curtime( ) 或 
Current_Time( ) 


返回 当前 的 系统 时 间 , 结果 为 字 
符 串 


Curtime( ) 
# 若 当前 系统 时 间 为 14:20:28, 则 
结果 为 "14:20:28" 





Date_ Add ( Date, Interval 
int Keyword ) 


返回 日 期 Date 加 上 间隔 时 间 int 的 
结果 , Keyword 可 以 是 Year Month 、 
Day .Hour Minute 等 


Date _ Add ( Curdate ( ) Interval 6 
Month ) ; 
# 当前 日 期 加 上 6 个 月 后 的 日 期 





Date_Format( Date, 
Format) 


按 指定 的 Format 格式 对 日 期 Date 
值 进行 格式 转换 


Date_Format( Now( ),’%d%b %Y 
%T:%f ) 

# 显 示 当 前 日 期 时 间 ,结果 为 22 Dec 
2015 14 :24 :08 :000000 





Date _ Sub ( Date，Interval 
int Keyword ) 


返回 日 期 Date 减 去 间隔 时 间 int 的 
结果 , Keyword 可 以 是 Year、 Month 、 
Day .Hour .Minute 等 


Date _ Sub ( Now ( ) Interval 48 
Hour) ; 

# 若 系统 日 期 为 2015-12-22 14:28: 
18 , 则 结果 为 2015-12-20 14:28:18 





DateDiff( Date , Date, ) 


日 期 差 函 数 。 返 回 Date, 与 Date, 
之 间 的 天 数 , 若 Date, 二 Date,, 则 函 
数 返回 值 为 大 于 或 等 于 0 的 整数 ， 
否则 为 负数 


DateDiff ( " 2016-10-01" ," 1949-10- 
01" ) 结 果 为 24472 





返回 Date 日 期 所 代表 的 一 星期 中 


DayofWeek( Now( ) ) 











DoyolWeek (Date) 的 第 几 天 (1 ~7) # 若 今 日 为 星期 二 , 则 结果 为 3 
-反问 FA 第 - | DayofMonth( Now( ) ) 
DayofMonth( Date) ee 日 期 所 在 月 份 的 第 几 天 | # 若 当前 系统 日 期 为 2015-12.22, 则 
函数 结果 为 22 
- 厂 有 i 本 入 . | DayofYear( Now( ) ) 
DivyorYéar( Date) ee 日 期 是 一 年 的 第 几 天 |; 若 当前 系统 日 期 为 2015-12.22 , 则 
函数 结果 为 356 
DayName( Now( ) ) 
DayName( Date) 返回 Date 日 期 的 英文 星期 名 # 若 当 前 系统 日 期 为 2015-12-22, 则 


函数 结果 为 Tuesday 





From_UNIXTime( ts, 
Format) 


根据 指定 的 Format 格式 对 UNIX 时 
间 惟 ts 进行 格式 转换 


From _ UNIXTime ( 12345678, "% 
Y-%m-%d % H:%i:% d" ) 结 果 为 
1970-05-24 05:21:18 





Hour( Time) 


返回 Time 的 小 时 值 (0 ~23) 


Hour( Now( ) ) 
# 若 系统 时 间 为 14:28:18, 则 结果 
为 14 





Minute(Time) 


返回 Time 的 分 钟 值 (0 ~59) 


Minute( Now( ) ) 
# 若 系统 时 间 为 14:28:18, 则 结果 
为 28 





Month( Date) 





返回 Date 的 月 份 值 (1 ~12) 





Month( Now( ) ) 
# 若 系统 日 期 为 2015-12-22 , 则 结果 
为 12 
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( 续 表 ) 





函数 格式 功能 及 说 明 应 用 示例 
MonthName( Now( ) ) 
MonthName( Date) 返回 Date 的 月 份 名 # 车 系统 日 期 为 2015-12-22, 则 结果 


为 December 





Now( ) 


返回 当前 的 日 期 和 时 间 


Now( ) 
# 若 系统 当前 日 期 2015-12-22 14:28: 
01 , 则 结果 为 2015-12-22 14:28:01 





Quarter( Date) 


返回 Date 在 一 年 中 的 季度 (1 ~4) 


Quarter( Now( ) ) 
# 若 系统 时 间 2015-12-22, 则 结果 
为 4 





TimeDiff( Date , Date, ) 


时 间 差 函数 。 两 个 日 期 时 间或 两 个 
时 间 之 间 相 隔 的 时 间 , 函数 返 回 值 
的 范围 为 - 838:59:59 ~ 838:59: 
59 , 即 函 数 只 适合 计算 不 超过 34 天 
23 小 时 的 时 间 间 隔 


TimeDiff( "2016-10-8 8:0:0'" ，2016- 
10-1 10:10:10' )# 结 果 为 165 :49:50 





返回 日 期 Date 为 一 年 中 第 几 周 


Week( Now( ) ) 
































Week(Date) # 若 系统 时 间 为 2015-12-22 , 则 结果 
(0~53) 
为 51 
返回 Date 对 应 的 工作 日 ( 周 几 ) , 范 | WeekDay( Now( )) 
WeekDay(Date) 围 是 0 ~6, 0 为 周一 ,1 为 周二 …6 | # 若 系统 时 间 为 2015-12-22 , 则 结果 
为 周 日 为 1 
汉 品 Year( Now( ) ) 
Year(Date) 返回 日 期 Date 的 年 份 (1000 ~ | # 震 系统 时 间 为 2015-12-22, 则 结果 
9999) 
为 2015 
表 A-5 MySQL 常用 聚合 函数 
函数 格式 功能 及 说 明 应 用 示例 
ee Select Avg( 笔试 成 绩 ) From GWCJB; 
Avg( col) 返回 指定 列 的 平均 值 # 笔试 成 绩 的 平均 值 
oiiCeol) 返回 指定 列 中 非 NULL 值 | Select Count( 身份 证 号 ) From GWCJB; 
的 个 数 # 统计 GWCJB 中 的 记录 个 数 
A Select Min( 笔试 成 绩 ) From GWCJB; 
Min( col) 返回 指定 列 的 最 小 值 # 笔试 成 绩 的 最 小 值 
村 Select Max( 笔试 成 绩 ) From GWCJB; 
Max(col) 返回 指定 列 的 最 大 值 # 笔试 成 绩 的 最 大 值 
而 乓 cs 天 Select Sum( 笔试 成 绩 ) From GWCJB; 
Sum( col) 返回 指定 列 的 所 有 值 之 和 # 笔试 成 绩 的 总 和 
各 :站 上 Select Group_Concat( 身份 证 号 ) From GWCJB; 
Group_Concat( col) ei # GWCJB 中 所 有 身份 证 号 连接 成 一 个 字符 串 ,每 个 
车 二 身份 证 号 间 用 逗号 分 隔 
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运算 格式 


表 A-6 MySQL 常用 位 运算 符 


功能 及 说 明 


应 用 示例 





十 式 勾 > 


式 1 与 式 2 按 位 与 运算 ,对 应 位 都 
为 1 结果 为 1 ,否则 为 0 


2&3 值 为 2 
# 数 值 2 的 二 进 制 格式 为 000…0010 
# 数 值 3 的 二 进 制 格式 为 000…0011 





式 1 与 式 2 按 位 或 运算 ,对 应 位 有 



























































运 武 下 坟 或 25 1 结果 为 1 否则 为 0 213 值 为 3 
式 1 与 式 2 按 位 异 或 运算 , 即 对 应 
< 武 15 ”< 起 23 Se 1, 对 应 位 不 同 结果 | 2 3 值 为 1 
:ki Re 8 在 04 位 系统 中 其 从 为 
18446744073709551613 
< 式 1> > > < 式 2 > | 式 1 按 位 右 移 式 2 指定 的 位 Ne 
< 式 1> < < < 式 2> | 式 1 按 位 左 移 式 2 指定 的 位 15 < <2 值 为 60 
表 A-7 ”MySQL 运算 符 的 优先 级 

优先 级 运算 符 

1( 最 高 ) !, Not 

2 一 ( 取 负 ) ，~ 〈 按 位 取 反 ) 

3 “( 按 位 界 或 ) 

4 * ，/，Div，% ，Mod 

5 十 ， 一 

6 < <( 按 位 左 移 ) ，> > ( 按 位 右 移 ) 

7 &( 按 位 与 运算 ) 

8 1( 按 位 或 运算 ) 

9 =( 相 等 比较 ), < =>, >=, >, <=, <,， <>,!=, Js, Like, Regexp, In 
10 Between, Case, When, Then, Else 

i &&, And 

入 ||, Or, Xor 

他 ”| 一 ( 民 信 ) ,: =( 复 全 赋值 运 算 符 ) 
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时 东 BB 


PHP 常用 运算 符 及 函数 


表 B-1 PHP 常用 数值 运算 及 函数 



































运算 及 函数 格式 功能 及 说 明 应 用 示例 

<m>+<m> 加 法 运算 5+2.8 值 为 7.8 
<m>- <m> 减法 运算 5 -2.8 值 为 2.2 
< > 乘法 运算 S*4 值 为 20 
< /Rm 除法 运算 20/5 值 为 4 
<m>% <m > 求 余 运 算 8%3 值 为 2 

i i $a=10;$b= ++$ai; 结果 $a 值 为 
十 十 前 级 加 法 11,$b 值 为 11 

$a=10;$b=$a++; 结果 $a 值 为 
十 十 后 级 加 法 11,$b 值 为 10 

i $a=10;$b= 一 一 $a; 结果 $a 值 为 
-- 前 级 减法 9, $b 值 为 9 

a i $a=10;$b=$a- -; 结 果 $#a 值 为 
-一 后 级 减法 9,$b 值 为 10 
Abs( x) 取 x 的 绝对 值 Abs( - 10.245) 值 为 10.245 

将 str 字符 串 由 x 进位 制 转换 为 | Base_ Convert(" 100" ,16,2 ) 结果 为 
Base_Convert( str,x,y) y 进 位 制 ,结果 以 字符 串 格式 | "100000000" 

存储 Base_Convert( "100" ,10,16) 结 果 为 "64" 





将 二 进 制 格式 字符 串 str 转换 成 














Bindec(str) 十 进 制 数值 Bindec("10011" ) 结 果 为 19 
向 上 舍 入 , 求 得 大 于 x 的 最 小 | Ceil(12.58) 结 果 为 13 

人 整数 Ceil( -20.4) 为 结果 为 -20 
Cos(x) 计算 x 的 余弦 值 Cos(2) 结 果 为 -0.41614683654714 
Decbin(x) 人 x 转换 为 二 进 制 格 Decbin(20) 结 果 为 "10100" 
Dechex(x) 将 十 进 制 数 x 转换 为 十 六 进 制 Dechex(20) 结果 为 "14" 





格式 字符 串 








( 续 表 ) 





























运算 及 函数 格式 功能 及 说 明 应 用 示例 

ecunt( ay bs 转换 为 八进制 格 | Decoct(20) 结 果 为 "24， 

Exp(x) 自然 对 数 e 的 x 次 方 值 Exp(2) 结 果 为 7.3890560989307 
Floor( 30. 48 ) 结果 为 30 

Val 计算 小 于 x 的 最 大 整数 Floor( -21.44) 结 果 为 -22 
返回 调用 Mt_rand( ) 函数 所 能 

Getrandmax( ) 返回 的 最 大 随机 数 Getrandmax( ) 结果 为 32767 

Hexdec( str) 人 sr 转 Hexdec("12" ) 结 果 为 18 

Log(x) x 的 自然 对 数值 Log( 100) 结果 为 4.6051701859881 

Logl0(x) 以 10 基底 的 x 对 数值 Log10(100) 结 果 为 2 

Max( ni nz，…，nm) 取 所 有 表达 式 中 的 最 大 值 Max(10,20.8 ,30) 结 果 为 30 

Min(ni ,nz，…，nm) 取 所 有 表达 式 中 的 最 小 值 Min(10.5,20.8,30) 结 果 为 10.5 





格式 化 数字 字符 串 str,n 为 小 数 


Number_Format( " 5000000" ,2 ) 结果 为 











Number_Format ( str,nyeci ， 点 后 的 位 数 ,c 为 小 数 点 符号 ， 5 ,000 ,000. 00 

cz) ce; 为 千 位 分 隔 符 符号 ,省 略 部 | Number _ Format ( " 5000000 "， 
分 参数 时 使 用 系统 默认 值 2,",",".") 结 果 为 5.000.000,00 

Octdec( str) ee sr 转化 成 Octdec("123" ) 结 果 为 83 

Pi() 圆周 率 Pi( ) 结 果 为 3. 1415926535898 

Pow(x,y) 计算 x 的 y 次 方 Pow(2,5 ) 结 果 为 32 





Rand(n, ,n,) 


取得 n, 和 n, 之 间 的 随机 整 
数值 


Rand(10,20) 结 果 为 10 ~20 之 间 的 随 
机 整数 ,例如 18 





舍 人 函数 ,保留 x 值 小 数 点 后 n 























Round(x,n) 位 ,四 舍 五 人 Round( 12. 488 ,2) 结 果 为 12.49 
Sin(x) 计算 x 的 正弦 值 Sin(2.5) 结 果 为 0.59847214410396 
Sqrt(x) 开平 方 根 Sqrt(100) 结 果 为 10 
Tan(x) 计算 x 的 正切 值 Tan(2) 结 果 为 -2.1850398632615 
表 B-2 PHP 常用 字符 运算 及 函数 
运算 及 函数 格式 功能 及 说 明 应 用 示例 
连接 运算 符 ,用 于 连接 两 个 字符 串 | "吉林 "." 大 学 "结果 为 "吉林 大 学 " 
_ 连接 赋值 运算 符 ,用 于 连接 两 个 字 | $a= "吉林 "; $A. =" 大 学 "; 结 
符 串 果 为 "吉林 大 学 " 
Strlen( str) 获取 sr 字符 串 长 度 , 每 个 汉字 或 全 | smen" 吾 林 大 学 *) 结 果 为 12 





角 符 号 占 3 个 字符 长 度 
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( 续 表 ) 





运算 及 函数 格式 功能 及 说 明 应 用 示例 
去 除 sen 字符 由 左 侧 开始 部 分 的 空 | 。，_，。 二 让 大 学 


Ltrim( str, [ ,str, ] ) 


格 ;如 有 参数 str, 则 是 将 sm 左 侧 
开始 的 空格 去 除 并 删除 str, 字符 串 
的 内 容 


Lutim( $$ a) 结果 为 "吉林 大 学 " 
Luim( $a," 吉林" ) 结 果 为 "大 学 " 





Rtrim( str [ ,str, ] ) 


去 除 sm 字符 串 右 侧 空格 ;如 有 参 
数 str, , 则 是 将 str, 右 侧 空格 去 除 并 
删除 右 侧 str, 字符 串 的 内 容 


$a=" 表 林 大 学 ，; 
Rtrim( $a) 结果 为 "吉林 大 学 " 
Rtrim( $a, "大 学 " ) 结 果 为 "吉林 " 





Trim( str, [ ,str, ] ) 


将 str 字符 串 两 侧 空格 去 除 ;车 有 
stn 参数 则 去 掉 str, 两 侧 st 子 串 
中 出 现 的 每 个 字符 


$a=" 吉林 大 学 "; 

$b=" 学 习 吉林 大 学 "; 
Trim( $a) 结 果 为 "吉林 大 学 " 
Trim( $b,， "学 大 ") 结 果 为 " 习 吉 
林 " 





Substr( str,n,m) 


从 str 字 符 串 第 n 个 字符 开始 ,连续 
截取 m 个 字符 形成 一 个 字符 串 , str 
字符 串 中 第 1 个 字符 位 置 从 0 开始 
计算 


Substr(" 吉林 大 学 图 书馆 " ,12,6) 
结果 为 "图 书 " 





Str _ Replace ( str, ,str,, 


将 strs 中 出 现 的 st 的 内 容 用 st 


Str_Replace(" 大 学 " ," 高 校 "," 吉 


林 大 学 大 学 城 " ) 结 果 为 "吉林 高 术 








st ) 替换 ,形成 新 的 结果 高 校 城 " 

返回 str 字符 串 中 的 英文 字母 全 部 | Strtoupper ("Asdafl23") 结果 为 
Strtoupper( str) 大 写 的 字符 串 " ASDAF123" 
Uefirst( str) 将 tr 字符 串 中 第 一 个 字符 变 成 大 | Uefrst( vaber ) 结 果 为 "Aben 


写 后 返回 





Htmlentities( str) 


将 str 字符 串 转换 为 HTML 实体 ,用 
echo 等 将 转换 后 str 字符 串 打印 在 
网 页 上 时 原样 输出 ,包括 标签 字符 
等 内 容 


echo Htmlentities(" < br/ > " ) ;// 结 
果 为 <br/ > 





Substr_Count( str, , str, ) 


返回 st 字符 串 在 str, 字符 串 中 出 
现 的 次 数 


Substr_Count( "吉林 大 学 大 学 城 " ," 
大 学 " ) 结 果 为 2 





Strpos( str , str, ) 


返回 st 字符 串 在 st 字符 串 中 第 
一 次 出 现 的 位 置 ,起 始 位 置 为 0; 若 
st 未 出 现在 str 中 , 函数 返 
回 False 


Sbpos(" 吉林 大 学 大 学 城 "," 大 ") 
结果 为 6 

Strpos(" 吉林 大 学 大 学 城 "," 吉林 
省 " ) 结果 为 False 





Strrpos( str, , str, ) 


返回 str, 字符 串 在 str, 字符 串 中 最 
后 一 次 出 现 的 位 置 


Stmrpos(" 吉林 大 学 大 学 城 "," 大 " ) 
结果 为 12 





Strstr( str, , str, ) 





返回 stn, 字符 串 中 第 一 个 出 现 sm 
字符 串 位 置 到 字符 串 结尾 的 全 部 
字符 





Strstr(" 吉林 大 学 大 学 城 "," 大 学 " ) 
结果 为 "大 学 大 学 城 " 
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(9)) 


运算 及 函数 格式 


( 续 表 ) 
功能 及 说 明 应 用 示例 





Strrchr( str, , str, ) 


返回 st 字符 串 中 从 最 后 一 次 出 现 
str, 字符 串 的 位 置 开 始 并 去 掉 最 后 
一 个 str, 之 后 的 字符 串 内 容 


Stmehr( "吉林 大 学 大 学 城 "," 大 
学 " ) 结 果 为 " 城 





Addcslashes( str, , str, ) 


将 str, 字符 串 中 每 一 个 字符 在 str, | Addeslashes ( "Jilin University " ， 
字符 串 中 出 现 的 相同 字符 前 加 "\"” | "is" ) 结 果 为 "J\il\in Un\iver\s\ity" 





Str_Pad( str,, n, str,, m) 


将 st 字符 串 扩 展 到 n 位 字符 长 
度 ,不 足 时 用 str, 填充 到 nm 指定 的 | $str="Hello Worldl" ; 

长 度 ) ,m 为 填充 方向 ,默认 为 右 侧 | echo Str_Pad( $str,20,"abe" ); 
填充 。 若 str, 长 度 大 于 或 等 于 n, 则 | /结果 为 "Hello World1abcabcab" 
函数 不 填充 任何 内 容 





Stremp( str, , str, ) 


运算 及 函数 格式 


逐个 比较 两 字符 串 对 应 位 置 字符 的 
ASCI 码 值 ,出 现 不 相同 时 , 如果 
str 中 的 字符 大 于 str, 对 应 位 置 的 
字符 ,函数 返回 1, 反之 返回 - 1, 两 
字符 串 完 全 一 样 返回 0 


Stremp("abe" ,"abd" ) 结 果 为 -1 
Stremp( "abc" ,"abc" ) 结 果 为 0 








表 B-3 PHP 常用 比较 .逻辑 运算 及 函数 
功能 及 说 明 应 用 示例 





< 式 1> = = < 式 2> 


$a=100; $b=100.0; 
相等 比较 , 若 式 1 等 于 式 2, 结果 为 | $a= = $b 结果 为 True 

True ,否则 结果 为 False "吉林 " = =" 吉 林 省 "结果 
为 False 





和 总 二 


全 等 比较 , 若 式 1 等 于 式 2 且 其 类 型 也 | $a=100; $b=100.0; 
相同 , 则 结果 为 True ,否则 结果 为 False $a= = =$b 结 果 为 False 





< 
< 式 1> < > < 式 2> 


不 等 于 比较 , 若 式 1 不 等 于 式 2, 则 结果 | 100 ! = 101 结果 为 True 
为 True ,否则 结果 为 False "abce" < >" Abc" 结果 为 Tme 





1>1s= < 起 2> 


非 全 等 比较 , 若 式 1 非 全 等 于 式 2, 则 结 | $a=100; $b=100.0; 
果 为 Tmue, 和 否则 结果 为 False $al= = $b 结果 为 True 





< 式 1> < < 式 2> 


小 于 比较 , 若 式 1 小 于 式 2 则 结果 为 | 100 <120 结果 为 True 
True ,否则 结果 为 False "AB" < "Ab" 结 果 为 True 





二 或 Ts < 式 2y> 


大 于 比较 , 若 式 1 大 于 式 2 则 结果 为 | 100 > 120 结果 为 False 
Tme ,否则 结果 为 False "AB" >" Ab" 结果 为 False 





< 式 1> < = < 式 2> 


小 于 或 等 于 比较 , 若 式 1 小 于 或 等 于 式 | 100 < =120 结果 为 True 
2 则 结果 为 Tmue ,否则 结果 为 False "AB" < ="Ab" 结 果 为 Tme 





忆 式 1> > < 起 2 光 





大 于 或 等 于 比较 , 若 式 1 大 于 或 等 于 式 | 100 > =120 结果 为 False 
2 则 结果 为 True ,否则 结果 为 False "AB" > = "Ab" 结 果 为 False 
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运算 及 函数 格式 


功能 及 说 明 


( 续 表 ) 
应 用 示例 





< 式 1>9? < 式 2>e 
< 式 3> 


条 件 运 算 符 , 计 算式 1, 若 其 结果 为 
Tme, 则 计算 式 2 并 将 式 2 的 结果 作为 
整个 表达 式 的 结果 ; 若 式 1 的 计算 结果 
为 False, 则 计算 式 3 并 将 式 3 的 结果 作 
为 整个 表达 式 的 结果 


$a=100; $b=120; 
$a> $b?$a: $b 结果 为 120 
$C=("AB" = ="AC")?7" 相 
同 " :" 不 相同 " ; 

// 结 果 $C 变量 赋值 为 "不 相 
同 " 





< 式 1> && < 式 2> 
< 式 1> And < 式 2> 


逻辑 与 运算 , 式 1 和 式 2 同时 为 True 时 
结果 为 True ,否则 为 False 


$a>10 And $a<20 
// 判 断 $a 的 值 是 否 落 在 10 ~ 
20 之 间 





< 起 13 上 < 式 23 
< 我 15 Or < 式 23 


逻辑 或 运算 , 式 1 和 式 2 两 者 至 少 有 一 
个 为 Tue 时 结果 为 True ,否则 为 False 


$a<10 Or $a>20 
// 判 断 $a 不 在 10 ~20 之 间 





< 式 1> Xor < 式 2> 


异 或 运算 , 式 1 和 式 2 结果 相反 时 表达 
式 结果 为 True ,否则 为 False 


笔试 成 绩 > = 60 Xor 面试 成 绩 
> =60 
// 判 断 单 科 及 格 的 情况 





t< 式 1> 


逻辑 非 运算 ,对 < 式 1 > 的 结果 取 反 , 即 
式 1 的 结果 为 Tue, 表达 式 的 结果 为 
False; 式 1 的 结果 为 False, 表 达 式 的 结 
果 为 Tme 


!( 笔试 成 绩 <60) 
// 判 断 笔 试 成 绩 合格 





File_Exists( str) 


判断 给 定 的 文件 是 否 存在 , 若 文 件 存在 ， 
函数 返回 True ,否则 返回 False 


File_FExists("d: \test. txt" ) 
//D 盘 根 目录 下 存在 文件 test. 
txt 时 函数 返回 True ,否则 False 





Is_Dir( str) 


检查 给 定 的 标识 符 是 否 是 目录 ,若是 则 
返回 Tmue, 和 否则 返回 False 


TIs_Dir(" dl:\test" ) 
//D 盘 根 目录 下 存在 test 文件 夹 
则 函数 返回 True ,否则 返回 False 





Mkdir( str) 


运算 及 函数 格式 





创建 给 定 的 目录 ,成 功 时 返回 Tme, 否 则 
返回 False。 若 路 径 描述 不 正确 , 则 无 法 
创建 给 定 的 目录 





Mkdir("d:\51180130" ) 
// 在 D 盘 根 目录 下 创建 51180130 
目录 
Mkdir("d:\51180130\temp\data" ) 
// 由 于 51180130 下 不 存在 temp 
目录 , 故 创建 data 目录 失败 ,也 
数 返 回 False 


表 B-4 PHP 常用 日 期 时 间 运 算 及 函数 


功能 及 说 明 


应 用 示例 





CheckDate ( Month, 
Year) 


验证 日 期 的 正确 性 ,函数 
返回 逻辑 值 


Day, 


CheckDate(2,10,2017) 结果 为 Tue 
CheckDate(2,30,2017) 结果 为 False 





Date( 格式 [ ,时 间 ]) 


格式 化 服务 器 的 时 间 , 形 
成 字符 串 格式 数据 返回 








Date("Y 年 m 月 d 日 H:i:s") 
// 按 格式 显示 系统 时 间 , 结 果 为 "2015 年 
12 月 22 日 14:33:28" 
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运算 及 函数 格式 


功能 及 说 明 


( 续 表 ) 
应 用 示例 





GetDate( ) 


获得 时 间 及 日 期 信息 , 结 
果 存 入 字符 数组 中 


$a=GetDate( ); 

Var_Dump( $a); 

// 显 示 数 组 中 的 11 个 元 素 值 

array( 11) 

|["seconds" ] = >int(44) 

"minutes" ] = >int(3) 

"hours" ] = >int(5) 

"mday" ] = >int(23) 

"wday" ] = > int(3) 

"mon" ] = >int(12) 

"year" ] = >int(2015) 

"yday" ] = >int(356) 

"weekday" ] = > string(9) " Wednesday" 
"month" ] = > string(8) "December" 
0] = > int(1450843424 ) | 








GetTimeOfDay( ) 


取得 当前 系统 时 间 , 结 果 
存 人 字符 数组 中 


$my_t = CetTimeOfDay( ) ; 

Var_dump( $my_t) ; 

// 输 出 数组 中 的 内 容 

array(4) 

1["sec" ] = >int(1450843692) 

"usec" ] = >int(496756) 

["minuteswest" ] = >int( -60) 
["dsttime" ] = >int(0) | 





MkTime ( Hour, Minute, 
Second, Month, Day, Year) 


取得 UNIX 时 间 戳 ,其 可 
以 自动 校正 越界 的 输入 


MkTime(0,0,0,12,36,2017) 
// 生 成 日 期 时 间 :2018-01-05 0:0:0 








取得 当前 系统 时 间 的 
UNIX 时 间 戳 ,时 间 鹤 是 





Time( ) 




















人 ee // 结 果 为 数值 ,例如 1450844406 
间 所 经 历 的 秒 数 
表 B-5 PHP 常用 正则 表达 式 
正则 表达 式 表达 式 说 明 
/\d+$/ 匹配 非 负 整数 
/ [09] *[1-9][0-9] * $/ 匹配 正 整 数 
/((-\d+)1(0+)) $/ 匹配 非 正 整数 
/-[0-9] * [1-9][0-9] * $/ 匹配 负 整数 
/-? \d+ $/ 匹配 整数 
/\d+(\.\d+)? $/ 匹配 非 负 浮 点 数 
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( 续 表 ) 





















































正则 表达 式 表达 式 说 明 
- 91+\- T0991 #1 -9 十 下 TREE 
9] * 匹配 正 浮 点 数 
093+}HE09}* FL9][9.9] + ))$ 
/C+ d+)?) (0+(\.0+)7)) $/" 匹配 非 正 浮 点 数 
CCfo09 Tv[09j [IT9j[029] =9] fiT9j[f0- 
9] * 匹配 负 浮 点 数 
-99]+》HLL99]* F1909] > 》》》 $A 
](-? \d+)(\.\d+)? $/ 匹配 浮 点 数 (整数 也 算 做 浮 点 数 ) 
/ [A-Za-z] + $/ 匹配 由 英文 字母 组 成 的 字符 串 
[AT] 匹配 由 大 写 英文 字母 组 成 的 字符 串 
/ [a-z]+$/ 匹配 由 小 写 英文 字母 组 成 的 字符 串 
/ [A-Za-z0-9] + $/ 匹配 由 数字 和 英文 字母 组 成 的 字符 串 
/ws $y/ 匹配 由 数字 、 英 文字 母 或 者 下 面 线 
组 成 的 字符 串 
] [\x|4e00|-\x|9fa5} ] + $/u 匹配 汉字 字符 串 





“[\x|4e00|-\x|9fa5| _a-zA-20-9] + $/u 


ee 


匹配 中 文英 文 ,数字 及 下 面 线 组 成 
的 字符 串 





/ [a-zA-Z][a-zA-20-9_]|4,15} $/ 


匹配 合法 账号 (字母 开头 ,允许 5 ~ 
16 字 节 ,允许 字母 数字 下 画 线 ) 





/[\w]+(\[\Ww] +)*@[\w]+(\.[\w]+)+ $/ 


匹配 Email 地 址 








# a-zA-z] + ://(\w+(-\w+)*)(\.(\w+(-\w+)+*))* 
(\? \S* )? 囊 # 


匹配 URL 地 址 





/(\d{1,2}11\d\dI2[04] \d125[0-5]). (\d{1,2}11\d\d12 
[04]\dl25[0.5]).(\dl1,2111\dvdl2[04] \d125[0-5]). (\d 
11,2111\dvdl2[04] \d125[0-5] ) $7 


匹配 IP 地 址 





/Cd|241\d141)-((OC1-9]411))1(1[01112]))-(([02] 
([1-9]411))1(3[011])) $7/ 


匹配 “年 -月 -日 "日 期 格式 (月 日 两 
位 ) 





/A (COC19I {14)) 10001112]))-(([0-2] (C1-9] 411))1(3 
[011]))-(\dl2}1\d|4}) $7/ 


匹配 “月 /日 /年 "日 期 格式 (月 日 两 
位 ) 

















/(\d{3}-1\d{4}-)? (\di8}1\d{71)? / 匹配 国内 电话 号 码 (固定 电话 ) 
A (CCMC\dl2,31))ICNdl3-))? 1\dl101$7/ 匹配 手机 号 码 (可 以 加 国家 区 号 ) 
/0\d{2,3} $/ 匹配 电话 区 号 

/人 [1-9]* [1-9][0-9] * $/ 匹配 腾讯 QQ 号 

/ (selectldropldeletelereatelupdatelinsert). * $/i 匹配 SQL 语句 
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表 B-6 PHP 运算 符 的 优先 级 






























































优先 级 运算 符 含义 结 
1( 最 高 ) | New 实例 化 
[ Array( ) 
! ~ ++ -- (no (foat) (string) 巡 辑 非 , 自 增 自 减 ,强制 右 
(array) (object) @ 类 型 转换 
4 * / % 算术 运算 态 
E: + - . 算术 运算 碍 
6 Ce 移 位 运算 左 
lk : < <= > >= 比较 运算 无 
8 二 间 E SREETUIEE 比较 运算 无 
9 & 按 位 与 运算 左 
10 按 位 异 或 运算 左 
11 1 按 位 或 运算 左 
12 && 逻辑 与 运算 左 
13 11 逻辑 或 运算 左 
14 ? : 条 件 运算 左 
15 | | 及 复合 大 值 运算 者 
16 Print 输出 右 
她 And 逻辑 与 运算 在 
18 Xor 逻辑 异 或 运算 左 
19 Or 逻辑 或 运算 左 
20( 最 低 ) | ， 逗号 运算 左 
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